数据库比对工具SQL(表、字段、触发器、索引、视图、存储过程)
做一个数据库比对小工具,把SQL做一个笔记
SELECT object_id AS ID --表ID
,'表' sType
,Name --表名
FROM sys.tables
ORDER BY Name
--字段
SELECT A.Name --字段名
,'字段' sType
,B.name AS typeName --字段类型
,A.max_length AS typeLength --长度(nvarchar要除以2 -1等于max)
,C.text AS defaultValue --默认值
,A.object_id AS PID --表名
,A.is_nullable AS [isNull] --是否为空
,A.is_identity AS isIdentity --是否值增长
, CASE WHEN IC.object_id IS NULL THEN 0 ELSE 1 END AS isPK --是否主键(自带聚集索引)
, CASE WHEN IC.object_id IS NULL THEN 0 ELSE 1 END AS isUnique --是否唯一
FROM sys.columns A
INNER JOIN sys.types B ON A.user_type_id=B.user_type_id
INNER JOIN sys.tables D ON D.object_id=A.object_id
LEFT JOIN sys.syscomments C ON A.default_object_id=C.id
LEFT JOIN sys.objects OB ON OB.parent_object_id=A.object_id AND OB.type='PK'
LEFT JOIN sys.indexes S ON S.name=OB.name
LEFT JOIN sys.index_columns IC ON IC.object_id = A.object_id AND ic.index_id=s.index_id AND ic.column_id=A.column_id
ORDER BY A.object_id,A.column_id
--非主键关联的索引
SELECT A.Name --索引名
,'索引' sType
,D.NAME AS colName --关联字段名
,A.object_id AS PID --表名
,A.type_desc AS typeDesc--索引类型
,A.is_unique AS isUnique --是否唯一
FROM SYS.INDEXES A
JOIN SYS.INDEX_COLUMNS B ON (A.object_id = B.object_id AND A.index_id = B.index_id)
JOIN SYS.TABLES C ON (A.object_id = C.object_id)
JOIN SYS.COLUMNS D ON (A.object_id = D.object_id AND B.column_id = D.column_id)
WHERE A.is_primary_key=0
ORDER BY A.object_id,B.index_column_id
--触发器
SELECT A.parent_id AS PID --表ID
,'触发器' sType
,A.Name --触发器名称
,B.Text --触发器内容
FROM sys.triggers A
INNER JOIN sys.syscomments B ON A.object_id=B.id
ORDER BY A.name
--视图
SELECT A.object_id AS ID
,'视图' sType
,A.Name --视图名
,B.definition Text --存储过程内容
FROM sys.views A
INNER JOIN sys.sql_modules B ON A.object_id=B.object_id
ORDER BY A.name
--存储过程
SELECT A.object_id AS ID
,'存储过程' sType
,A.Name --存储过程名称
,B.definition Text --存储过程内容
FROM sys.procedures A
INNER JOIN sys.sql_modules B ON A.object_id=B.object_id
ORDER BY A.name
我很平凡
没有过人的天分
没有命运的恩宠
世界不公平。
但我知道
有一个倔强的我
不甘平庸
渴望自由
潜能无限
我相信
只要执着和努力
总有一天
让世界的不公平
在我面前低头!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
· 25岁的心里话