SQL Server查找一个外键被引用的所有表

直接上代码:

 1 SELECT  oSub.name AS [子表名称] ,
 2         fk.name AS [外键名称] ,
 3         SubCol.name AS [子表列名] ,
 4         oMain.name AS [主表名称] ,
 5         MainCol.name AS [主表列名]
 6 FROM    sys.foreign_keys fk
 7         JOIN sys.all_objects oSub ON ( fk.parent_object_id = oSub.object_id )
 8         JOIN sys.all_objects oMain ON ( fk.referenced_object_id = oMain.object_id )
 9         JOIN sys.foreign_key_columns fkCols ON ( fk.object_id = fkCols.constraint_object_id )
10         JOIN sys.columns SubCol ON ( oSub.object_id = SubCol.object_id
11                                      AND fkCols.parent_column_id = SubCol.column_id
12                                    )
13         JOIN sys.columns MainCol ON ( oMain.object_id = MainCol.object_id
14                                       AND fkCols.referenced_column_id = MainCol.column_id
15                                     )
16 WHERE   fk.name LIKE @FOREIGN KEY;
@FOREIGN KEY :外键键名 
时间: 2024-08-24 10:23:03

SQL Server查找一个外键被引用的所有表的相关文章

SQL Server中建立外键的方法

在SQL中建立外键约束,可以级联查询表中的数据,在C#代码生成器中,也能根据外键关系生成相应的外键表数据模型.外键也可防止删除有外键关系的记录,一定程度上保护了数据的安全性. 步骤: 1.要建立外键关系,首先要保证用来建立外键关系的列具有唯一性,即具有 UNIQUE 约束通常是某表的主键作为另外一个表的外键 2.打开数据库表,找到要建立外键的表.并确保其中要建立外键关系的列与主键表中的数据类型完全一致 3.在要建立外键关系的表中,在任意列上右击,选择[关系] 4.在外键关系对话框中,点击左下角的

Sql Server有主外键关系时添加、删除数据

当表之间有主外键关系时删除数据会被约束,添加.删除失败 解决办法,我们可以先把主外键关系的检查约束给关掉 → 然后删除数据 → 之后再把约束打开 查询出关掉所有外键约束的语句 SELECT 'ALTER TABLE ' + O.NAME + ' NOCHECK CONSTRAINT [' + F.NAME + '];' AS COMMAND FROM SYS.FOREIGN_KEYS F INNER JOIN SYS.ALL_OBJECTS O ON F.PARENT_OBJECT_ID = O

SQL Server 查询所有外键子父表关系

SELECT table_name,fk_name,reference_table_name,fk_list_number,fk_detailFROM (SELECT object_name(f.object_id) AS fk_name,object_name(f.parent_object_id) AS table_name,object_name(f.referenced_object_id) AS reference_table_name,k.constraint_column_id A

MS SQL巡检系列——检查外键字段是否缺少索引

前言感想:一时兴起,突然想写一个关于MS SQL的巡检系列方面的文章,因为我觉得这方面的知识分享是有价值,也是非常有意义的.一方面,很多经验不足的人,对于巡检有点茫然,不知道要从哪些方面巡检,另外一方面,网上关于MS SQL巡检方面的资料好像也不是特别多.写这个系列只是一个分享,自己的初衷是一个知识梳理.总结提炼过程,有些知识和脚本也不是原创,文章很多地方融入了自己的一些想法和见解的,不足和肤浅之处肯定也非常多,抛砖引玉,也希望大家提意见和建议.补充,指正其中的不足之处.Stay Hungry

但从谈论性能点SQL Server选择聚集索引键

简单介绍 在SQL Server中,数据是按页进行存放的.而为表加上聚集索引后,SQL Server对于数据的查找就是依照聚集索引的列作为keyword进行了. 因此对于聚集索引的选择对性能的影响就变得十分重要了.本文从旨在从性能的角度来谈聚集索引的选择,但这不过从性能方面考虑.对于有特殊业务要求的表,则须要按实际情况进行选择. 聚集索引所在的列或列的组合最好是唯一的 这个原因须要从数据的存放原理来谈. 在SQL Server中,数据的存放方式并非以行(Row)为单位.而是以页为单位.因此.在查

SQL Server中一个隐性的IO性能杀手-Forwarded record

原文:SQL Server中一个隐性的IO性能杀手-Forwarded record 简介     最近在一个客户那里注意到一个计数器很高(Forwarded Records/Sec),伴随着间歇性的磁盘等待队列的波动.本篇文章分享什么是forwarded record,并从原理上谈一谈为什么Forwarded record会造成额外的IO.   存放原理     在SQL Server中,当数据是以堆的形式存放时,数据是无序的,所有非聚集索引的指针存放指向物理地址的RID.当数据行中的变长列增

SQL Server 查找表问题

使用以下SQL遍历表,查询是否有问题 DECLARE @table_name VARCHAR(50) DECLARE cursor_table CURSOR FOR SELECT name FROM sys.tables OPEN cursor_table FETCH next FROM cursor_table INTO @table_name WHILE( @@FETCH_STATUS = 0 ) BEGIN DBCC checktable(@table_name) PRINT ' ' PR

SQL Server 查找统计信息的采样时间与采样比例

原文:SQL Server 查找统计信息的采样时间与采样比例 有时候我们会遇到,由于统计信息不准确导致优化器生成了一个错误的执行计划(或者这样表达:一个较差的执行计划),从而引起了系统性能问题.那么如果我们怀疑这个错误的执行计划是由于统计信息不准确引起的.那么我们如何判断统计信息不准确呢?当然首先得去查看实际执行计划中,统计信息的相关数据是否与实际情况有较大的出入,下面我们抛开这个大命题,仅仅从统计信息层面去查看统计信息的更新时间,统计信息的采样行数.采样比例等情况. 1:首先,我们要查查统计信

55.ORM外键:引用同app下的不同模型,引用不同app下的模型,引用模型自身使用详解

外键和表关系 外键是属于数据库级别的,在MySQL中,表有两种引擎,一种是InnoDB,另外一种是myisam.如果使用的是InnoDB引擎,是支持外键约束的.外键的存在使得ORM框架在处理表关系的时候异常强大.因此这里我们首先来介绍外键在Django中的使用. 类定义为 class ForeignKey(to,on_delete,**options).第一个参数to是应用的哪个模型(也就是应用的表),第二个参数on_delete在使用外键应用的模型数据被删除了,这个字段该如何处理.举例说明,如