理解中系统表的
关于SQL Server数据库的一切信息都保存在它的系统表格里。我怀疑你是否花过比较多的时间来检查系统表格,因为你总是忙于用户表格。但是,你可能需要偶尔做一点不同寻常的事,例如数据库所有的触发器。你可以一个一个地检查表格,但是如果你有500个表格的话,这可能会消耗相当大的人工。
这就让Sysobjects表格有了用武之地。虽然我不建议你更新这个表格,但是你当然有权对其进行审查。
在大多数情况下,对你最有用的两个列是和ype。前面一个用来列出待考察对象的名字,而后一个用来定义对象的类型:
C:检查约束。 D:默认的约束 F:外键约束 L:日志
P:存储过程 PK:主键约束 RF:复制过滤存储过程
S:系统表格 TR:触发器 U:用于表格。
质量等原因 UQ:独特的约束 V:视图 X:被扩展的存储过程
在碰到触发器的情形下,用来识别触发器类型的其他三个列是:deltrig、instrig和uptrig。
你可以用下面的命令列出感兴趣的所有对象:
SELECT * FROM sysobjects WHERE xtype = type of interest
在特殊情况下,也就是在父表格拥有触发器的情况下,你可能想要用下面这样的代码查找数据库:
SELECT Sys2.[name] TableName, Sys1.[name] TriggerName, CASE WHEN ltrig 0 THEN\"Delete\" WHEN strig 0 THEN\"Insert\" WHEN dtrig 0 THEN\"Update\" END\"TriggerType\" FROM sysobjects Sys1 JOIN sysobjects Sys2 ON rent_obj = Sys2.[id] WHERE ype=\"TR\"ORDERBY TableName
在SQL Server 2005里,首选的技术是使用系统视图。这种方式会把你的查询同微软选择对系统表格进行的任何改变隔绝开来。
下面是一个简单的例子,它使用了INFORMATION_SCHEMA_TABLES视图:
SELECT TABLE_SCHEMA, TABLE_NAME, TABLE_TYPE FROMINFORMATION_BLESORDERBY TABLE_SCHEMA, TABLE_NAME
对于AdventureWorks数据库或者任何你自己的数据库,使用这个查询可以产生一个表格快速列表。
为了说明这些架构查询的能力,看下面的语句,它们列出所选数据库里所有的函数和存储过程。
SELECT*FROMINFORMATION_UTINESORDERBY ROUTINE_TYPE, ROUTINE_NAME
市面上有20种这样的信息架构视图。如果你需要将数据库归档,而且无法承担商业解决方案,例如Red Gate或者Apex提供的方案的话,那么通过这些视图和一点点试验,你就可以让SQL Server给自己生成文档了。
杭州白癜风医院排名昆明哪里专业治白癜风
广州治疗妇科习惯性流产费用
-
“做高仿”的莆田鞋子,开始打假了?
有新技术也有能够的福清袜子,极为重要的是来作自己。 正解本局不止品 “...
2023-12-06
-
昌转型生态企业|生物医药产业转型加速度,医健伙伴再释新能
近日,由中华民族英泰药剂开发设计工作团队直接参与积极开展的新型STAR-T类...
2023-11-28
-
一年自然流产2次、胎盘畸形,28岁的她如何成功让宝宝着陆的?
对于大多数女人来讲,和爱的人在夫妇有一个爱的粉末,是一件很令人期望和...
2023-11-08
-
兰格建筑钢材日可见一斑:市场价以稳为主 需求整体偏弱
布洛克巴洛克式骨架材日亦同:市场期望价以稳有别于 期望整体而言偏弱 ...
2023-10-29
-
有一种成功叫吃亏!请相信:只想吃亏,终究都不吃亏
有一种如此一来功叫出头!请相信:总有一天出头,终将都不出头 出头是福...
2023-10-28
-
美股跌幅扩展 纳指跌超1%
美股暴跌增加 纳指跌超1% 【美股暴跌增加 纳指跌超1%】财联社5月20日电,美...
2023-10-27