共计 2081 个字符,预计需要花费 6 分钟才能阅读完成。
本篇文章为大家展示了 SQL Server 中具有默认值的所有字段的语句有哪些,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。
专家解答 通过查询任何数据库中的三个系统表,你可以获得每个表的每一个字段的默认值。下面是这个核心查询。它返回分配给当前数据库中每个用户表的默认值。这个查询在 SQL 2000 和 SQL 2005 中都是兼容的。Quote: 复制代码 代码如下:
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 , 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 AND SM.TEXT = (0) ORDER BY SO.[name], SC.colid 选择 2:只返回具有默认值字段的信息 修改核心查询的 WHERE 条件语句来忽略 syscomments.text 表中的 NULL 值,这个技巧如下所示:Quote: 复制代码 代码如下:
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 AND SM.TEXT IS NOT NULL ORDER BY SO.[name], SC.colid
但是,将 FROM 条件从句中的 JOIN 从一个 LEFT JOIN 改为一个 INNER JOIN 会提供优化:Quote: 复制代码 代码如下:
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 INNER JOIN dbo.syscomments SM ON SC.cdefault = SM.id WHERE SO.xtype = U ORDER BY SO.[name], SC.colid
其实还有另一个选择,利用 SQL 2005 中的系统目录视图。前面的查询给我提供了这时所需要的信息,并在 SQL 2000 和 SQL 2005 中都可以使用,在 SQL2000 实例中可以挖掘出与这个默认值 (实际上是一个默认约束) 关联的额外元数据。通过将这个查询特定在系统目录视图上,我们可以获得在之前的查询中没有显示出来的额外信息。Quote: 复制代码 代码如下:
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
所以记住,就因为你被告知没有更好的方法,依靠你作为一个数据库管理员的本能来钻研。你永远不会知道你可能会得到些什么。
上述内容就是 SQL Server 中具有默认值的所有字段的语句有哪些,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注丸趣 TV 行业资讯频道。