全球唯一標(biāo)識符由128位整數(shù)組成,你可以利用它進(jìn)入任何一臺需要輸入唯一標(biāo)識符的電腦或任何一個需要唯一標(biāo)識符的網(wǎng)絡(luò)。Tony Patton講解了.NET Framework是怎樣教你創(chuàng)建自己的全球唯一標(biāo)識符的。
TechRepublic的free.NET時事通訊每周三刊發(fā),在討論諸如網(wǎng)頁服務(wù), ASP.NET, ADO.NET, 以及 Visual Studio .NET的問題時,里面舉出了一些有用的提示和編碼的例子。你現(xiàn)在就可以訂閱。
當(dāng)Windows的開發(fā)者們需要一個唯一值的時候,通常他們會用一個全球唯一標(biāo)識符。微軟用全球唯一標(biāo)識符這一述語來描述一個唯一的數(shù)字,它可以識別一個諸如Word文本之類的實體。
一個全球唯一標(biāo)識符由128位整數(shù)(16字節(jié))組成,你可以利用它進(jìn)入任何一臺需要輸入唯一標(biāo)識符的電腦或任何一個需要唯一標(biāo)識符的網(wǎng) 絡(luò)。這種類型的標(biāo)識符被復(fù)制的可能性非常小。
本文講解了.NET Framework怎樣幫你創(chuàng)建你自己的全球唯一標(biāo)識符。
無論在哪里,你都會看到全球唯一標(biāo)識符總是在Windows環(huán)境中操作。當(dāng)你在Windows系統(tǒng)中細(xì)讀注冊表時,你會發(fā)現(xiàn)全球唯一標(biāo)識符被廣泛用來識別應(yīng)用程序等等。在HKEY_CLASSES_ROOT中,它甚至被用作應(yīng)用軟件的標(biāo)識符。
936DA01F-9ABD-4d9d-80C7-02AF85C822A8是一個典型的全球唯一標(biāo)識符的格式。
擁有一個全球唯一標(biāo)識符就能更容易地存儲或重新找回信息。尤其當(dāng)涉及到數(shù)據(jù)庫的時候,它的這一功能就顯得更為突出,這是因為全球唯一標(biāo)識符可以幫助你設(shè)置一個絕好的主鍵。
同樣,SQL Server也支持全球唯一標(biāo)識符,它可以存儲一個uniqueidentifier數(shù)據(jù)類型的全球唯一標(biāo)識符。你可以用NEWID()功能在SQL Server中設(shè)置一個標(biāo)識符值,也可以在其它系統(tǒng)中設(shè)置標(biāo)識符值然后再手動將該值插入SQL Server中。
在.NET中后一種方法很直截了當(dāng)。.NET Framework中的基本的系統(tǒng)類包括全球唯一標(biāo)識符的值類型。此外,這個值類型中包括了使用全球唯一標(biāo)識符值的方法。而NweGUID法則能讓你輕易地創(chuàng)建一個新的全球唯一標(biāo)識符。
創(chuàng)建起來也非常簡單:Guid tempId = Guid.NewGuid(); 這樣就可以了!
用.NET創(chuàng)建一個全球唯一標(biāo)識符
GUID(Global unique identifier)全局唯一標(biāo)識符,它是由網(wǎng)卡上的標(biāo)識數(shù)字(每個網(wǎng)卡都有唯一的標(biāo)識號)以及 CPU 時鐘的唯一數(shù)字生成的的一個 16 字節(jié)的二進(jìn)制值。
GUID 的格式為“xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx”,其中每個 x 是 0-9 或 a-f 范圍內(nèi)的一個十六進(jìn)制的數(shù)字。例如:6F9619FF-8B86-D011-B42D-00C04FC964FF 即為有效的 GUID 值。
世界上的任何兩臺計算機(jī)都不會生成重復(fù)的 GUID 值。GUID 主要用于在擁有多個節(jié)點、多臺計算機(jī)的網(wǎng)絡(luò)或系統(tǒng)中,分配必須具有唯一性的標(biāo)識符。在 Windows 平臺上,GUID 應(yīng)用非常廣泛:注冊表、類及接口標(biāo)識、數(shù)據(jù)庫、甚至自動生成的機(jī)器名、目錄名等。
1、在 SQL Server 中使用 GUID
如果在 SQL Server 的表定義中將列類型指定為 uniqueidentifier,則列的值就為 GUID 類型。
SQL Server 中的 NewID() 函數(shù)可以產(chǎn)生 GUID 唯一值,使用此函數(shù)的幾種方式如下:
1) 作為列默認(rèn)值
將 uniqueidentifier 的列的默認(rèn)值設(shè)為 NewID(),這樣當(dāng)新行插入表中時,會自動生成此列 GUID 值。
2)使用 T-SQL
在 T-SQL 中使用 NewID()函數(shù),如“Insert INTO Table(ID,... ) VALUES(NewID(),...)”來生成此列的 GUID 值。
3)提前獲取 GUID 值
由于特殊功能需要,需要預(yù)先獲知新行的 ID 值,也可以使用如下 C# 代碼提前獲得 GUID 的值,再存儲到數(shù)據(jù)庫中:
SqlCommand cmd = New SqlCommand();
cmd.CommandText = "Select NewID()";
string rowID = (string) cmd.ExecuteScalar();
cmd.CommandText = "Insert INTO Table(ID,...) VALUES(@ID,...)
cmd.Parameters.Add("@ID",SqlDbType.UniqueIdentifier).Value = new Guid(rowID);
cmd.ExecuteNoQuery();
uniqueidentifier 值不能進(jìn)行算術(shù)運算,但可以進(jìn)行(意義不大的)比較操作和 NULL 檢查;它不能象 IDENTITY 列一樣,可以獲知每行的增加時間的先后順序,只能通過增加其它時間或時間戳列來完成此功能。
2、在 .NET 中使用 GUID
GUID 在 .NET 中使用非常廣泛,而且 .NET Framework 提供了專門 Guid 基礎(chǔ)結(jié)構(gòu)。
Guid 結(jié)構(gòu)的常用法包括:
1) System.Guid.NewGuid()()
生成一個新的 GUID 唯一值
2) Guid.ToString()
將 GUID 值轉(zhuǎn)換成字符串,便于處理
3)構(gòu)造函數(shù) Guid(string)
由 string 生成 Guid 結(jié)構(gòu),其中string 可以為大寫,也可以為小寫,可以包含兩端的定界符“{}”或“()”,甚至可以省略中間的“-”,Guid 結(jié)構(gòu)的構(gòu)造函數(shù)有很多,其它構(gòu)造用法并不常用。
同時,為了適用數(shù)據(jù)庫中使用 GUID 的需要,.NET Framework 也提供了 SqlGUID 結(jié)構(gòu),它和 Guid 結(jié)構(gòu)類似,只是兩者對排序(CompareTo)的處理方式不同,SqlGuid 計算值的最后 6 個字節(jié)。而 Guid 計算全部 16 個字節(jié),這種差異可能會給 SQL Server 中 uniqueidentifier 列的排序帶來一定影響,當(dāng)然這種排序意義也不大。
.NET Framework 中可以使用類 GuidConverter 提供將 Guid 結(jié)構(gòu)與各種其他表示形式相互轉(zhuǎn)換的類型轉(zhuǎn)換器。
3、GUID 的優(yōu)缺點
1) 優(yōu)點
同 IDENTITY 列相比,uniqueidentifier 列可以通過 NewID() 函數(shù)提前得知新增加的行 ID,為應(yīng)用程序的后續(xù)處理提供了很大方便。
便于數(shù)據(jù)庫移植,其它數(shù)據(jù)庫中并不一定具有 IDENTITY 列,而 Guid 列可以作為字符型列轉(zhuǎn)換到其它數(shù)據(jù)庫中,同時將應(yīng)用程序中產(chǎn)生的 GUID 值存入數(shù)據(jù)庫,它不會對原有數(shù)據(jù)帶來影響。
便于數(shù)據(jù)庫初始化,如果應(yīng)用程序要加載一些初始數(shù)據(jù), IDENTITY 列的處理方式就比較麻煩,而 uniqueidentifier 列則無需任何處理,直接用 T-SQL 加載即可。
便于對某些對象或常量進(jìn)行永久標(biāo)識,如類的 ClassID,對象的實例標(biāo)識,UDDI 中的聯(lián)系人、服務(wù)接口、tModel標(biāo)識定義等。
2) 缺點
GUID 值較長,不容易記憶和輸入,而且這個值是隨機(jī)、無順序的,所以使用時要注意場合,最好不要嘗試用它來作為你的電子郵件地址 J
GUID 的值有 16 個字節(jié),與其它那些諸如 4 字節(jié)的整數(shù)相比要相對大一些。這意味著如果在數(shù)據(jù)庫中使用 uniqueidentifier 鍵,可能會帶來兩方面的消極影響:存儲空間增大;索引時間較慢。