sql server表外鍵查詢


--本表外鍵
SELECT
f.name AS foreign_key_name
,OBJECT_NAME(f.parent_object_id) AS table_name
,COL_NAME(fc.parent_object_id, fc.parent_column_id) AS constraint_column_name
,OBJECT_NAME (f.referenced_object_id) AS referenced_object
,COL_NAME(fc.referenced_object_id, fc.referenced_column_id) AS referenced_column_name
,is_disabled
,delete_referential_action_desc
,update_referential_action_desc
FROM sys.foreign_keys AS f
INNER JOIN sys.foreign_key_columns AS fc
ON f.object_id = fc.constraint_object_id
WHERE f.parent_object_id = OBJECT_ID('table_name');


--外鍵被參考表
SELECT 主鍵列ID=b.rkey
    ,主鍵列名=(SELECT name FROM syscolumns WHERE colid=b.rkey AND id=b.rkeyid)
    ,外鍵表ID=b.fkeyid
    ,外鍵表名稱=object_name(b.fkeyid)
    ,外鍵列ID=b.fkey
    ,外鍵列名=(SELECT name FROM syscolumns WHERE colid=b.fkey AND id=b.fkeyid)
    ,級聯更新=ObjectProperty(a.id,'CnstIsUpdateCascade')
    ,級聯刪除=ObjectProperty(a.id,'CnstIsDeleteCascade')
FROM sysobjects a
    join sysforeignkeys b on a.id=b.constid
    join sysobjects c on a.parent_obj=c.id
where a.xtype='f' AND c.xtype='U'
    and object_name(b.rkeyid)='table_name'

 sql server指定數據庫所有表結構查詢:

SELECT
CASE
        
    WHEN
        col.colorder = 1 THEN
            obj.name ELSE '' 
            END AS 表名,
        col.colorder AS 序號 ,
        col.name AS 列名 ,
        ISNULL( ep.[value], '' ) AS 列說明 ,
        t.name AS 數據類型 ,
        col.length AS 長度 ,
        ISNULL( COLUMNPROPERTY( col.id, col.name, 'Scale' ), 0 ) AS 小數位數 ,
    CASE
            
            WHEN COLUMNPROPERTY( col.id, col.name, 'IsIdentity' ) = 1 THEN
            '' ELSE '' 
        END AS 標識 ,
    CASE
            
            WHEN EXISTS (
            SELECT
                1 
            FROM
                dbo.sysindexes si
                INNER JOIN dbo.sysindexkeys sik ON si.id = sik.id 
                AND si.indid = sik.indid
                INNER JOIN dbo.syscolumns sc ON sc.id = sik.id 
                AND sc.colid = sik.colid
                INNER JOIN dbo.sysobjects so ON so.name = si.name 
                AND so.xtype = 'PK' 
            WHERE
                sc.id = col.id 
                AND sc.colid = col.colid 
                ) THEN
                '' ELSE '' 
            END AS 主鍵 ,
        CASE
                
                WHEN col.isnullable = 1 THEN
                '' ELSE '' 
            END AS 允許空 ,
            ISNULL( comm.text, '' ) AS 默認值 
        FROM
            dbo.syscolumns col
            LEFT JOIN dbo.systypes t ON col.xtype = t.xusertype
            INNER JOIN dbo.sysobjects obj ON col.id = obj.id 
            AND obj.xtype = 'U' 
            AND obj.status >= 0
            LEFT JOIN dbo.syscomments comm ON col.cdefault = comm.id
            LEFT JOIN sys.extended_properties ep ON col.id = ep.major_id 
            AND col.colid = ep.minor_id 
            AND ep.name = 'MS_Description'
            LEFT JOIN sys.extended_properties epTwo ON obj.id = epTwo.major_id 
            AND epTwo.minor_id = 0 
            AND epTwo.name = 'MS_Description' 
    WHERE
    obj.name IN ( SELECT sys.tables.name as TableName from sys.tables)

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM