列出SQL Server中具有默认值的所有字段的语句
前端之家收集整理的这篇文章主要介绍了
列出SQL Server中具有默认值的所有字段的语句,
前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
专家解答
通过查询任何数据库中的三个系统表,你可以获得每个表的每一个字段的默认值。下面是这个核心查询。它返回分配给当前数据库中每个用户表的默认值。这个查询在sql 2000和sql 2005中都是兼容的。
Quote:
<div class="codetitle"><a style="CURSOR: pointer" data="48650" class="copybut" id="copybut48650" onclick="doCopy('code48650')"> 代码如下:
<div class="codebody" id="code48650">
SELECT SO.NAME AS "Table Name",SC.NAME AS "Column Name",SM.TEXT AS "Default Value"
FROM dbo.sysobjects SO INNER JOIN dbo.syscolumns SC ON SO.id = SC.id
LEFT JOIN dbo.syscomments SM ON SC.cdefault = SM.id
WHERE SO.xtype = 'U'
ORDER BY SO.[name],SC.colid
sysobjects 为我们提供了表元数据。在这个例子中,我们只对表
名称感兴趣。syscolumns 表存储与每个表的各个字段相关联的元数据。在这个例子中,我们只需要字段
名称。最后,默认值元数据由syscomments表提供。
对Northwind
数据库运行这个
查询生成下面的结果(为了简短,省略了一些记录)。注意,因为LEFT JOIN到syscomments表所以它将返回NULL默认值。
现在我在想这个很好的基本
查询版本有什么选择。。。
选择1:
搜索特别的默认值
通过编辑WHERE条件语句,我们可以在所有的表中查看特别的默认值。
Quote:
SELECT SO.NAME AS "Table Name",SM.TEXT AS "Default Value"
FROM dbo.sysobjects SO INNER JOIN dbo.syscolumns SC ON SO.id = SC.id
LEFT JOIN dbo.syscomments SM ON SC.cdefault = SM.id
WHERE SO.xtype = 'U' AND SM.TEXT = '(0)'
ORDER BY SO.[name],SC.colid
选择2:只返回具有默认值字段的信息
修改核心
查询的WHERE条件语句来忽略syscomments.text表中的NULL值,这个技巧如下所示:
Quote:
<div class="codetitle">
<a style="CURSOR: pointer" data="40364" class="copybut" id="copybut40364" onclick="doCopy('code40364')"> 代码如下: