當前位置:範文城>行業範本>資料庫作業系統>

關於使用GUID值來作為資料庫行標識的講解

資料庫作業系統 閱讀(7.49K)

GUID(Globaluniqueidentifier)全域性唯一識別符號,它是由網絡卡上的標識數字(每個網絡卡都有唯一的標識號)以及CPU時鐘的唯一數字生成的的一個16位元組的二進位制值。

關於使用GUID值來作為資料庫行標識的講解

GUID的格式為“xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx”,其中每個x是0-9或a-f範圍內的一個十六進位制的數字。例如:6F9619FF-8B86-D011-B42D-00C04FC964FF即為有效的GUID值。

世界上的任何兩臺計算機都不會生成重複的GUID值。GUID主要用於在擁有多個節點、多臺計算機的網路或系統中,分配必須具有唯一性的識別符號。在Windows平臺上,GUID應用非常廣泛:登錄檔、類及介面標識、資料庫、甚至自動生成的機器名、目錄名等。

在這次開發應用時,我大量使用了型別為GUID的ID列作為各實體表的關鍵字(鍵)。由於其唯一、易產生的`特性,給應用程式處理帶來諸多好處。

1、在SQLServer中使用GUID

如果在SQLServer的表定義中將列型別指定為uniqueidentifier,則列的值就為GUID型別。

SQLServer中的NewID()函式可以產生GUID唯一值,使用此函式的幾種方式如下:

1)作為列預設值

將uniqueidentifier的列的預設值設為NewID(),這樣當新行插入表中時,會自動生成此列GUID值。

2)使用T-SQL

在T-SQL中使用NewID()函式,如“INSERTINTOTable(ID,...)VALUES(NewID(),...)”來生成此列的GUID值。

3)提前獲取GUID值

由於特殊功能需要,需要預先獲知新行的ID值,也可以使用如下C#程式碼提前獲得GUID的值,再儲存到資料庫中:

SqlCommandcmd=NewSqlCommand();

andText="SELECTNewID()";

stringrowID=(string)uteScalar();

andText="INSERTINTOTable(ID,...)VALUES(@ID,...)

("@ID",ueIdentifier)e=newGuid(rowID);

uteNoQuery();

uniqueidentifier值不能進行算術運算,但可以進行(意義不大的)比較操作和NULL檢查;它不能象IDENTITY列一樣,可以獲知每行的增加時間的先後順序,只能通過增加其它時間或時間戳列來完成此功能。

2、在中使用GUID

GUID在中使用非常廣泛,而且ramework提供了專門Guid基礎結構。

Guid結構的常用法包括:

1)UID()

生成一個新的GUID唯一值

2)ring()

將GUID值轉換成字串,便於處理

3)建構函式Guid(string)

由string生成Guid結構,其中string可以為大寫,也可以為小寫,可以包含兩端的定界符“{}”或“()”,甚至可以省略中間的“-”,Guid結構的建構函式有很多,其它構造用法並不常用。

同時,為了適用資料庫中使用GUID的需要,ramework也提供了SqlGUID結構,它和Guid結構類似,只是兩者對排序(CompareTo)的處理方式不同,SqlGuid計算值的最後6個位元組。而Guid計算全部16個位元組,這種差異可能會給SQLServer中uniqueidentifier列的排序帶來一定影響,當然這種排序意義也不大。

ramework中可以使用類GuidConverter提供將Guid結構與各種其他表示形式相互轉換的型別轉換器。

3、GUID的優缺點

1)優點

同IDENTITY列相比,uniqueidentifier列可以通過NewID()函式提前得知新增加的行ID,為應用程式的後續處理提供了很大方便。

便於資料庫移植,其它資料庫中並不一定具有IDENTITY列,而Guid列可以作為字元型列轉換到其它資料庫中,同時將應用程式中產生的GUID值存入資料庫,它不會對原有資料帶來影響。

便於資料庫初始化,如果應用程式要載入一些初始資料,IDENTITY列的處理方式就比較麻煩,而uniqueidentifier列則無需任何處理,直接用T-SQL載入即可。

便於對某些物件或常量進行永久標識,如類的ClassID,物件的例項標識,UDDI中的聯絡人、服務介面、tModel標識定義等。

2)缺點

GUID值較長,不容易記憶和輸入,而且這個值是隨機、無順序的,所以使用時要注意場合,最好不要嘗試用它來作為你的電子郵件地址J

GUID的值有16個位元組,與其它那些諸如4位元組的整數相比要相對大一些。這意味著如果在資料庫中使用uniqueidentifier鍵,可能會帶來兩方面的消極影響:儲存空間增大;索引時間較慢。

綜合來說,GUID的優點帶來的便利遠超出其缺點帶來的影響,隨著諸如WebService等系統互聯與整合技術的不斷髮展,其唯一標識的特性使得其應用越來越廣,在您的應用程式中也應考慮使用它了。