溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

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

發(fā)布時間:2021-10-13 11:49:28 來源:億速云 閱讀:181 作者:柒染 欄目:數(shù)據(jù)庫

本篇文章為大家展示了SQL Server中具有默認(rèn)值的所有字段的語句有哪些,內(nèi)容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。

專家解答   通過查詢?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ù)庫運(yùn)行這個查詢生成下面的結(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)不會知道你可能會得到些什么。

上述內(nèi)容就是SQL Server中具有默認(rèn)值的所有字段的語句有哪些,你們學(xué)到知識或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識儲備,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI