中易网

如何在sqlserver查询中与一个表约束的其它表名

答案:2  悬赏:50  
解决时间 2021-04-28 10:05
  • 提问者网友:心裂忍耐
  • 2021-04-27 18:54
如何在sqlserver查询中与一个表约束的其它表名
最佳答案
  • 二级知识专家网友:不服输就别哭
  • 2021-04-27 19:39
主键约束
SELECt
tab.name AS [表名],
idx.name AS [主键名称],
col.name AS [主键列名]
FROM
sys.indexes idx
JOIN sys.index_columns idxCol
ON (idx.object_id = idxCol.object_id
AND idx.index_id = idxCol.index_id
AND idx.is_primary_key = 1)
JOIN sys.tables tab
ON (idx.object_id = tab.object_id)
JOIN sys.columns col
ON (idx.object_id = col.object_id
AND idxCol.column_id = col.column_id);

唯一约束
SELECt
tab.name AS [表名],
idx.name AS [约束名称],
col.name AS [约束列名]
FROM
sys.indexes idx
JOIN sys.index_columns idxCol
ON (idx.object_id = idxCol.object_id
AND idx.index_id = idxCol.index_id
AND idx.is_unique_constraint = 1)
JOIN sys.tables tab
ON (idx.object_id = tab.object_id)
JOIN sys.columns col
ON (idx.object_id = col.object_id
AND idxCol.column_id = col.column_id);

外键约束
select
oSub.name AS [子表名称],
fk.name AS [外键名称],
SubCol.name AS [子表列名],
oMain.name AS [主表名称],
MainCol.name AS [主表列名]
from
sys.foreign_keys fk
JOIN sys.all_objects oSub
ON (fk.parent_object_id = oSub.object_id)
JOIN sys.all_objects oMain
ON (fk.referenced_object_id = oMain.object_id)
JOIN sys.foreign_key_columns fkCols
ON (fk.object_id = fkCols.constraint_object_id)
JOIN sys.columns SubCol
ON (oSub.object_id = SubCol.object_id
AND fkCols.parent_column_id = SubCol.column_id)
JOIN sys.columns MainCol
ON (oMain.object_id = MainCol.object_id
AND fkCols.referenced_column_id = MainCol.column_id)

Check约束
SELECt
tab.name AS [表名],
chk.name AS [Check约束名],
col.name AS [列名],
chk.definition
FROM
sys.check_constraints chk
JOIN sys.tables tab
ON (chk.parent_object_id = tab.object_id)
JOIN sys.columns col
ON (chk.parent_object_id = col.object_id
AND chk.parent_column_id = col.column_id)
全部回答
  • 1楼网友:哥在撩妹请勿打扰
  • 2021-04-27 21:13
create table aa ( bb int unique ); select tab.name as [表名], idx.name as [约束名称], col.name as [约束列名] from sys.indexes idx join sys.index_columns idxcol on (idx.object_id = idxcol.object_id and idx.index_id = idxcol.index_id and idx.is_unique_constraint = 1) join sys.tables tab on (idx.object_id = tab.object_id) join sys.columns col on (idx.object_id = col.object_id and idxcol.column_id = col.column_id) where tab.name = 'aa' 表名 约束名称 约束列名 aa uq__aa__3214b5c34460231c bb
我要举报
如以上回答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
点此我要举报以上问答信息!
大家都在看
推荐信息