濮阳杆衣贸易有限公司

主頁 > 知識庫 > 列出SQL Server中具有默認(rèn)值的所有字段的語句

列出SQL Server中具有默認(rèn)值的所有字段的語句

熱門標(biāo)簽:溫州語音外呼系統(tǒng)排名 四川穩(wěn)定外呼系統(tǒng)公司 怎么在高德地圖標(biāo)注多個點 AI智能云呼電話機器人怎么注冊 沈陽外呼系統(tǒng)有效果嗎 福州外呼系統(tǒng)招商 電話機器人接口是什么樣的 百度地圖標(biāo)注信息怎么修改 商家地圖標(biāo)注圖片
專家解答
  通過查詢?nèi)魏螖?shù)據(jù)庫中的三個系統(tǒng)表,你可以獲得每個表的每一個字段的默認(rèn)值。下面是這個核心查詢。它返回分配給當(dāng)前數(shù)據(jù)庫中每個用戶表的默認(rèn)值。這個查詢在SQL 2000和SQL 2005中都是兼容的。
  
Quote: 
復(fù)制代碼 代碼如下:

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 為我們提供了表元數(shù)據(jù)。在這個例子中,我們只對表名稱感興趣。syscolumns 表存儲與每個表的各個字段相關(guān)聯(lián)的元數(shù)據(jù)。在這個例子中,我們只需要字段名稱。最后,默認(rèn)值元數(shù)據(jù)由syscomments表提供。
  對Northwind數(shù)據(jù)庫運行這個查詢生成下面的結(jié)果(為了簡短,省略了一些記錄)。注意,因為LEFT JOIN到syscomments表所以它將返回NULL默認(rèn)值。
按此在新窗口打開圖片
現(xiàn)在我在想這個很好的基本查詢版本有什么選擇。。。
  選擇1:搜索特別的默認(rèn)值
  通過編輯WHERE條件語句,我們可以在所有的表中查看特別的默認(rèn)值。
  
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:只返回具有默認(rèn)值字段的信息
  修改核心查詢的WHERE條件語句來忽略syscomments.text表中的NULL值,這個技巧如下所示:
  
Quote:
復(fù)制代碼 代碼如下:

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會提供優(yōu)化:
  
Quote:
復(fù)制代碼 代碼如下:

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中的系統(tǒng)目錄視圖。前面的查詢給我提供了這時所需要的信息,并在SQL 2000和SQL 2005中都可以使用,在SQL2000實例中可以挖掘出與這個默認(rèn)值(實際上是一個默認(rèn)約束)關(guān)聯(lián)的額外元數(shù)據(jù)。通過將這個查詢特定在系統(tǒng)目錄視圖上,我們可以獲得在之前的查詢中沒有顯示出來的額外信息。
  
Quote:
復(fù)制代碼 代碼如下:

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
按此在新窗口打開圖片
所以記住,就因為你被告知沒有更好的方法,依靠你作為一個數(shù)據(jù)庫管理員的本能來鉆研。你永遠(yuǎn)不會知道你可能會得到些什么。
您可能感興趣的文章:
  • input之怎么清除默認(rèn)值
  • 用sql設(shè)置access的默認(rèn)值
  • MySQL表字段設(shè)置默認(rèn)值(圖文教程及注意細(xì)節(jié))

標(biāo)簽:汕尾 邯鄲 寶雞 來賓 無錫 七臺河 營口 西寧

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《列出SQL Server中具有默認(rèn)值的所有字段的語句》,本文關(guān)鍵詞  列出,SQL,Server,中,具有,默認(rèn)值,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《列出SQL Server中具有默認(rèn)值的所有字段的語句》相關(guān)的同類信息!
  • 本頁收集關(guān)于列出SQL Server中具有默認(rèn)值的所有字段的語句的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    冀州市| 手机| 隆回县| 梁河县| 浦城县| 乡宁县| 江阴市| 华坪县| 凤台县| 子长县| 呼玛县| 额尔古纳市| 荣成市| 和田市| 武宁县| 闸北区| 鄂伦春自治旗| 霞浦县| 伊川县| 乐安县| 高州市| 丹巴县| 曲沃县| 汉源县| 潮安县| 哈尔滨市| 年辖:市辖区| 肃宁县| 刚察县| 崇礼县| 柘城县| 西乌| 丰台区| 汽车| 全椒县| 南康市| 镇安县| 农安县| 醴陵市| 武城县| 福鼎市|