SQL Server的空值處理策略

來源:互聯網
上載者:User
資料完整性是任何 資料庫系統要保證的重點。不管系統計劃得有多好,空資料值的問題總是存在。本文探討了在 SQL Server中處理這些值時涉及的3個問題:計數、使用空表值以及外鍵處理。

  用COUNT(*)處理空值

  大多數集合函數都能在計算時消除空值;COUNT函數則屬於例外。對包含空值的一個列使用COUNT函數,空值會從計算中消除。但假如COUNT函數使用一個星號,它就計算所有行,而不管是否存在空值。

  如果希望COUNT函數對給定列的所有行(包括空值)進行計數,請使用ISNULL函數。ISNULL函數會將空值替換成有效值。

  事實上,對集合函數來說,如果空值可能導致錯誤結果,ISNULL函數就非常有用。記住在使用一個星號時,COUNT函數會對所有行進行計算。下例示範了空值在AVG和COUNT集合函數中的影響:

  SET NOCOUNT ON

  GO

  CREATE TABLE xCount

  (pkey1 INT IDENTITY NOT NULL

  CONSTRAINT pk_xCount PRIMARY KEY,

  Col1 int NULL)

  GO

  INSERT xCount (Col1) VALUES (10)

  GO

  INSERT xCount (Col1) VALUES (15)

  GO

  INSERT xCount (Col1) VALUES (20)

  GO

  INSERT xCount (Col1) VALUES (NULL)

  GO

  SELECT AVG(Col1) AvgWithoutIsNullFunctionOnCol1,

  AVG(ISNULL(Col1,0)) AvgWithIsNullFunctionOnCol1,

  COUNT(Col1) NoIsNullFunctionOnCol1 ,

  COUNT(ISNULL(Col1,0)) UsinGISNullFunctionOnCol1,

  Count(*) UsingAsterisk

  FROM xCount

  GO

  DROP TABLE xCount

  GO

  OUTPUT:

  AvgWOIsNullFnctnCol1 AvgWIsNullFnctnCol1 WOIsNullFnctnCol1

  WIsNullFnctnCol1 UsingAsterisk

  ---------------- ------------- -------------- ------------

  15 11 3 4 4

  恰當使用空表值

  SQL Server可能出現一種特殊情況:在引用父表的一個表中,因為不允許空值,所以“聲明參考完整性”(DRI)可能不會得到強制。即使父表不包含空值,在子表引用了父表主鍵約束或惟一約束的列中,也可能包含空值。

  假如來自父表的值目前未知,就不會有任何問題。例如,父表可能是一個地址表,而子表可能包含聯絡資訊。由於許多原因,可能暫時不知道要傳給父表的聯絡地址。這是一種基於時間的問題,空值在其中或許是合適的。

  如下例所示,我們建立父表,並在其中插入兩個值。

  SET NOCOUNT ON

  GOCREATE TABLE Parent(pkey1 INT IDENTITY NOT NULL

  CONSTRAINT pkParent PRIMARY KEY,col1 INT NULL)GOINSERT

  Parent (col1) VALUES (284)GOINSERT

  Parent (col1) VALUES (326)GO

  以下代碼則建立子表,並在引用父表的列中插入一個空值。

  CREATE TABLE Child

  (pkey1 INT IDENTITYCONSTRAINT pkChild

  PRIMARY KEY,Parentpkey1 INT NULLCONSTRAINT fkChildParent

  FOREIGN KEYREFERENCES Parent(pkey1),col1 INT NULL)

  GOINSERT Child (Parentpkey1, col1) VALUES (null,2) GO

  但在以下代碼中,要同時從父表和子表選擇值。雖然父表不包含空值,但在子表引用了父表的那個列中,將允許一個空值。

  然後丟棄所有表,清除這個示範所用的資料庫物件。

  SELECT * FROM ChildGOSELECT * FROM ParentGODROP TABLE Child, ParentGO

  在可以為空白的外鍵中檢查資料的有效性

  如果由兩個列共同組成主鍵,而且一個子表將主鍵作為可為空白值的外鍵來繼承,就可能得到錯誤的資料。可在一個外鍵列中插入有效值,但在另一個外鍵列中插入空值。然後,可添加一個資料表檢查約束,在可為空白的外鍵中檢查資料的有效性。

  任何多列外鍵都可能遇到同樣的問題。所以,你需要添加一個檢查約束來檢測異常。最初,檢查約束將檢查構成外鍵的所有列中可能為空白的值。檢查約束還要檢查這些列中不可為空的值。如兩個檢查都通過,問題就解決了。

  以下示範指令碼展示了這樣的一個異常,以及如何用檢查約束來糾正它。

  空值是所有資料庫開發人員和管理員都要遇到的。所以,要想開發成功的應用程式,必須知道如何處理這些值。本文和你分享了空值處理的一些技巧和技術。
轉載:http://www.51testing.com/html/96/n-142796.html

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.