列出SQL Server中具有默认值的所有字段的语句

前端之家收集整理的这篇文章主要介绍了列出SQL Server中具有默认值的所有字段的语句前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

专家解答 @H_301_0@  通过查询任何数据库中的三个系统表,你可以获得每个表的每一个字段的默认值。下面是这个核心查询。它返回分配给当前数据库中每个用户表的默认值。这个查询sql 2000和sql 2005中都是兼容的。 @H_3010@   @H3010@Quote:@H301_0@<div class="codetitle"><a style="CURSOR: pointer" data="48650" class="copybut" id="copybut48650" onclick="doCopy('code48650')"> 代码如下:

<div class="codebody" id="code48650">@H_3010@SELECT SO.NAME AS "Table Name",SC.NAME AS "Column Name",SM.TEXT AS "Default Value" @H3010@  FROM dbo.sysobjects SO INNER JOIN dbo.syscolumns SC ON SO.id = SC.id @H3010@  LEFT JOIN dbo.syscomments SM ON SC.cdefault = SM.id @H3010@  WHERE SO.xtype = 'U' @H3010@  ORDER BY SO.[name],SC.colid@H3010@
@H301_0@  sysobjects 为我们提供了表元数据。在这个例子中,我们只对表名称感兴趣。syscolumns 表存储与每个表的各个字段相关联的元数据。在这个例子中,我们只需要字段名称。最后,默认值元数据由syscomments表提供。 @H_301_0@  对Northwind数据库运行这个查询生成下面的结果(为了简短,省略了一些记录)。注意,因为LEFT JOIN到syscomments表所以它将返回NULL默认值。 @H_3010@按此在新窗口打开图片@H301_0@现在我在想这个很好的基本查询版本有什么选择。。。 @H_301_0@  选择1:搜索特别的默认值 @H_3010@  通过编辑WHERE条件语句,我们可以在所有的表中查看特别的默认值。 @H3010@   @H3010@Quote: @H3010@SELECT SO.NAME AS "Table Name",SM.TEXT AS "Default Value" @H3010@  FROM dbo.sysobjects SO INNER JOIN dbo.syscolumns SC ON SO.id = SC.id @H3010@  LEFT JOIN dbo.syscomments SM ON SC.cdefault = SM.id @H3010@  WHERE SO.xtype = 'U' AND SM.TEXT = '(0)' @H3010@  ORDER BY SO.[name],SC.colid @H3010@选择2:只返回具有默认值字段的信息 @H301_0@  修改核心查询的WHERE条件语句来忽略syscomments.text表中的NULL值,这个技巧如下所示: @H_3010@   @H3010@Quote: @H301_0@<div class="codetitle"><a style="CURSOR: pointer" data="40364" class="copybut" id="copybut40364" onclick="doCopy('code40364')"> 代码如下:
<div class="codebody" id="code40364">@H_3010@SELECT SO.NAME AS "Table Name",SM.TEXT AS "Default Value" @H3010@  FROM dbo.sysobjects SO INNER JOIN dbo.syscolumns SC ON SO.id = SC.id @H3010@  LEFT JOIN dbo.syscomments SM ON SC.cdefault = SM.id @H3010@  WHERE SO.xtype = 'U' AND SM.TEXT IS NOT NULL @H3010@  ORDER BY SO.[name],SC.colid @H3010@
@H3010@  但是,将FROM条件从句中的JOIN从一个LEFT JOIN改为一个INNER JOIN会提供优化: @H3010@   @H3010@Quote: @H301_0@<div class="codetitle"><a style="CURSOR: pointer" data="18338" class="copybut" id="copybut18338" onclick="doCopy('code18338')"> 代码如下:
<div class="codebody" id="code18338">@H_3010@SELECT SO.NAME AS "Table Name",SM.TEXT AS "Default Value" @H3010@  FROM dbo.sysobjects SO INNER JOIN dbo.syscolumns SC ON SO.id = SC.id @H3010@  INNER JOIN dbo.syscomments SM ON SC.cdefault = SM.id @H3010@  WHERE SO.xtype = 'U' @H3010@  ORDER BY SO.[name],SC.colid @H3010@
@H3010@按此在新窗口打开图片@H301_0@  其实还有另一个选择,利用sql 2005中的系统目录视图。前面的查询给我提供了这时所需要的信息,并在sql 2000和sql 2005中都可以使用,在sql2000实例中可以挖掘出与这个默认值(实际上是一个默认约束)关联的额外元数据。通过将这个查询特定在系统目录视图上,我们可以获得在之前的查询中没有显示出来的额外信息。 @H_3010@   @H3010@Quote: @H301_0@<div class="codetitle"><a style="CURSOR: pointer" data="57859" class="copybut" id="copybut57859" onclick="doCopy('code57859')"> 代码如下:
<div class="codebody" id="code57859">@H_3010@SELECT ST.[name] AS "Table Name",SC.[name] AS "Column Name",SD.definition AS "Default Value",SD.[name] AS "Constraint Name" @H301_0@  FROM sys.tables ST INNER JOIN sys.syscolumns SC ON ST.[objectid] = SC.[id] @H301_0@  INNER JOIN sys.default_constraints SD ON ST.[object_id] = SD.[parent_object_id] AND SC.colid = SD.parent_columnid @H3010@  ORDER BY ST.[name],SC.colid @H3010@按此在新窗口打开图片@H301_0@所以记住,就因为你被告知没有更好的方法,依靠你作为一个数据库管理员的本能来钻研。你永远不会知道你可能会得到些什么。

Server字段字段默认值默认值

猜你在找的MsSQL相关文章