此文章主要介绍的是列出SQL Server默认值中的所有字段,上个星期我在对一个供应商开发的实际应用数据库按规定进行故障排除的时候,我们需要对他们数据库中50个表的每一个都进行查看,以确保所有期望是SQL Server默认值的字段都被分配了默认值。
你可以想象这是一个多么令人畏惧的工作,而我立即提
上个星期我在对一个供应商开发的数据库按规定进行故障排除的时候,我们需要对他们数据库中50个表的每一个都进行查看,以确保所有期望是默认值的字段都被分配了默认值。你可以想象这是一个多么令人畏惧的工作,而我立即提出了这个问题。有没有一个比在SQL Server管理套件中打开每一个表来查看这个schema的更好 *** 吗?
专家解答
通过查询任何数据库中的三个系统表,你可以获得每个表的每一个字段的SQL Server默认值。下面是这个核心查询。它返回分配给当前数据库中每个用户表的SQL Server默认值。这个查询在SQL 2000和SQL 2005中都是兼容的。
SELECT SO.NAME AS "Table Name", SC.NAME AS "Column Name", *** .TEXT AS "Default Value" FROM dbo.sysobjects SO INNER JOIN dbo.syscolumns SC ON SO.id = SC.id LEFT JOIN dbo.syscomments *** ON SC.cdefault = *** .id WHERE SO.xtype = 'U' ORDER BY SO.[name], SC.colid
sysobjects 为我们提供了表元数据。在这个例子中,我们只对表名称感兴趣。syscolumns 表存储与每个表的各个字段相关联的元数据。在这个例子中,我们只需要字段名称。最后,SQL Server默认值元数据由syscomments表提供。
对Northwind数据库运行这个查询生成下面的结果(为了简短,省略了一些记录)。注意,因为LEFT JOIN到syscomments表所以它将返回NULL默认值。
现在我在想这个很好的基本查询版本有什么选择。。。
选择1:搜索特别的默认值
通过编辑WHERE条件语句,我们可以在所有的表中查看特别的SQL Server默认值。
SELECT SO.NAME AS "Table Name", SC.NAME AS "Column Name", *** .TEXT AS "Default Value" FROM dbo.sysobjects SO INNER JOIN dbo.syscolumns SC ON SO.id = SC.id LEFT JOIN dbo.syscomments *** ON SC.cdefault = *** .id WHERE SO.xtype = 'U' AND *** .TEXT = '(0)' ORDER BY SO.[name], SC.colid
选择2:只返回具有SQL Server默认值字段的信息
修改核心查询的WHERE条件语句来忽略syscomments.text表中的NULL值,这个技巧如下所示:
SELECT SO.NAME AS "Table Name", SC.NAME AS "Column Name", *** .TEXT AS "Default Value" FROM dbo.sysobjects SO INNER JOIN dbo.syscolumns SC ON SO.id = SC.id LEFT JOIN dbo.syscomments *** ON SC.cdefault = *** .id WHERE SO.xtype = 'U' AND *** .TEXT IS NOT NULL ORDER BY SO.[name], SC.colid
但是,将FROM条件从句中的JOIN从一个LEFT JOIN改为一个INNER JOIN会提供优化:
SELECT SO.NAME AS "Table Name", SC.NAME AS "Column Name", *** .TEXT AS "Default Value" FROM dbo.sysobjects SO INNER JOIN dbo.syscolumns SC ON SO.id = SC.id INNER JOIN dbo.syscomments *** ON SC.cdefault = *** .id WHERE SO.xtype = 'U' ORDER BY SO.[name], SC.colid
其实还有另一个选择,利用SQL 2005中的系统目录视图。前面的查询给我提供了这时所需要的信息,并在SQL 2000和SQL 2005中都可以使用,在SQL2000实例中可以挖掘出与这个SQL Server默认值(实际上是一个默认约束)关联的额外元数据。通过将这个查询特定在系统目录视图上,我们可以获得在之前的查询中没有显示出来的额外信息。
SELECT st.[name] AS "Table Name", SC.[name] AS "Column Name", SD.definition AS "Default Value", SD.[name] AS "Constraint Name" FROM sys.tables ST INNER JOIN sys.syscolumns SC ON ST.[object_id] = SC.[id] INNER JOIN sys.default_constraints SD ON ST.[object_id] = SD.[parent_object_id] AND SC.colid = SD.parent_column_id ORDER BY ST.[name], SC.colid
所以记住,就因为你被告知没有更好的 *** ,依靠你作为一个数据库管理员的本能来钻研。你永远不会知道你可能会得到些什么。
出现该问题的原因是由于使用第三方优化软件消除快捷方式的小箭头引起的。 1、在开始搜索框中键入“regedit”,按回车键打开注册表编辑器。 2、依次定位到以下分支:HKEY_CLASSES_ROOTlnkfile。 3、在lnkfile项上鼠标右键单击“新建”——“字符串值”。...
重装系统是我们面对许多电脑问题时的终极方法,不过重装系统也不意味着就能将全部的问题都修复。一些用户在重装系统后开机时,电脑卡在“正在启动Windows”开机界面上了,这要怎么解决呢? Windows 7系统重装后卡在开机界面的解决方法: 一、首先可以看看该故障出现的原因是否是因为启动了acp...
Ubuntu挂载U盘问题 复制代码代码如下: 老是说special device /dev/sdb1 does not exist,无比郁闷 复制代码代码如下:#fdisk /dev/sda 复制代码代码如下: 是有个 这个咚咚。。。。 复制代码代码如下: 最后: 复制代码代码如下:...
电脑开机速度不够快?如何才能加快电脑开机速度呢?今天小编就教大家一个通过禁止nvcpl服务项加快Windows 7电脑开机速度的方法。 解决方法: 1、首先按“WIN+R”组合键打开Windows 7系统的“运行”窗口,输入“services.msc”命令后按回车。 2、在打开的服务窗口中...
电脑桌面右下角出现测试模式 Windows 7 内部版本7601如何去掉?不知道大家是否存在这个问题,前段时间作者刚刚处理了这个事情,现将处理步骤介绍如下。 1、单击“开始”——“所有程序” 2、打开“附件” 3、找到“命令行提示符”,右键选择“以管理员身份运行” 4、在命令行窗...
Ubuntu在使用命令的时候,有时需要修改命令提示符PS1,可很多人并不知道如何修改PS1,下面小编就给大家介绍下Ubuntu如何修改命令提示符PS1,一起来学习下吧。 命令多行输入不方便也不直观,要想修改这个命令提示符。修改~/.bashrc文件中的PS1即可。 PS1是主要的提示符设置,...