国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > SQL Server > 正文

列出SQL Server中具有默認值的所有字段的語句

2024-08-31 00:59:55
字體:
來源:轉載
供稿:網友
專家解答
  通過查詢任何數據庫中的三個系統表,你可以獲得每個表的每一個字段的默認值。下面是這個核心查詢。它返回分配給當前數據庫中每個用戶表的默認值。這個查詢在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默認值。

列出SQL Server中具有默認值的所有字段的語句


現在我在想這個很好的基本查詢版本有什么選擇。。。
  選擇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 Server中具有默認值的所有字段的語句


  其實還有另一個選擇,利用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中具有默認值的所有字段的語句


所以記住,就因為你被告知沒有更好的方法,依靠你作為一個數據庫管理員的本能來鉆研。你永遠不會知道你可能會得到些什么。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 永仁县| 石嘴山市| 泊头市| 沈丘县| 周至县| 闽清县| 陕西省| 云霄县| 金塔县| 南城县| 六安市| 北川| 沛县| 金山区| 太康县| 武穴市| 会宁县| 宣化县| 彩票| 高安市| 黔南| 滁州市| 长子县| 武汉市| 贵定县| 东莞市| 沧州市| 西平县| 社旗县| 墨竹工卡县| 张掖市| 剑阁县| 温泉县| 天门市| 来安县| 忻城县| 准格尔旗| 新源县| 水富县| 呼伦贝尔市| 泰和县|