GUID(Global unique identifier)全局唯一標識符它是由網卡上的標識數字(每個網卡都有唯一的標識號)以及 CPU 時鐘的唯一數字生成的的一個 字節的二進制值
GUID 的格式為xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx其中每個 x 是 或 af 范圍內的一個十六進制的數字例如FFFBDBDCFCFF 即為有效的 GUID 值
世界上的任何兩台計算機都不會生成重復的 GUID 值GUID 主要用於在擁有多個節點多台計算機的網絡或系統中分配必須具有唯一性的標識符在 Windows 平台上GUID 應用非常廣泛注冊表類及接口標識數據庫甚至自動生成的機器名目錄名等
在這次開發 ASPNET 應用時我大量使用了類型為 GUID 的 ID 列作為各實體表的關鍵字(鍵)由於其唯一易產生的特性給應用程序處理帶來諸多好處
在 SQL Server 中使用 GUID
如果在 SQL Server 的表定義中將列類型指定為 uniqueidentifier則列的值就為 GUID 類型
SQL Server 中的 NewID() 函數可以產生 GUID 唯一值使用此函數的幾種方式如下
) 作為列默認值
將 uniqueidentifier 的列的默認值設為 NewID()這樣當新行插入表中時會自動生成此列 GUID 值
)使用 TSQL
在 TSQL 中使用 NewID()函數如INSERT INTO Table(ID ) VALUES(NewID())來生成此列的 GUID 值
)提前獲取 GUID 值
由於特殊功能需要需要預先獲知新行的 ID 值也可以使用如下 C# 代碼提前獲得 GUID 的值再存儲到數據庫中:
SqlCommand cmd = New SqlCommand();
cmdCommandText = SELECT NewID();
string rowID = (string) cmdExecuteScalar();
cmdCommandText = INSERT INTO Table(ID) VALUES(@ID)
cmdParametersAdd(@IDSqlDbTypeUniqueIdentifier)Value = new Guid(rowID);
cmdExecuteNoQuery();
uniqueidentifier 值不能進行算術運算但可以進行(意義不大的)比較操作和 NULL 檢查它不能象 IDENTITY 列一樣可以獲知每行的增加時間的先後順序只能通過增加其它時間或時間戳列來完成此功能
>>PS:Oracle獲取guid的方式為sys_guid()
在 NET 中使用 GUID
GUID 在 NET 中使用非常廣泛而且 NET Framework 提供了專門 Guid 基礎結構
Guid 結構的常用法包括
) GuidNewGUID()
生成一個新的 GUID 唯一值
) GuidToString()
將 GUID 值轉換成字符串便於處理
)構造函數 Guid(string)
由 string 生成 Guid 結構其中string 可以為大寫也可以為小寫可以包含兩端的定界符{}或()甚至可以省略中間的Guid 結構的構造函數有很多其它構造用法並不常用
同時為了適用數據庫中使用 GUID 的需要NET Framework 也提供了 SqlGUID 結構它和 Guid 結構類似只是兩者對排序(CompareTo)的處理方式不同SqlGuid 計算值的最後 個字節而 Guid 計算全部 個字節這種差異可能會給 SQL Server 中 uniqueidentifier 列的排序帶來一定影響當然這種排序意義也不大
NET Framework 中可以使用類 GuidConverter 提供將 Guid 結構與各種其他表示形式相互轉換的類型轉換器
GUID 的優缺點
) 優點
同 IDENTITY 列相比uniqueidentifier 列可以通過 NewID() 函數提前得知新增加的行 ID為應用程序的後續處理提供了很大方便
便於數據庫移植其它數據庫中並不一定具有 IDENTITY 列而 Guid 列可以作為字符型列轉換到其它數據庫中同時將應用程序中產生的 GUID 值存入數據庫它不會對原有數據帶來影響
便於數據庫初始化如果應用程序要加載一些初始數據 IDENTITY 列的處理方式就比較麻煩而 uniqueidentifier 列則無需任何處理直接用 TSQL 加載即可
便於對某些對象或常量進行永久標識如類的 ClassID對象的實例標識UDDI 中的聯系人服務接口tModel標識定義等
) 缺點
GUID 值較長不容易記憶和輸入而且這個值是隨機無順序的所以使用時要注意場合最好不要嘗試用它來作為你的電子郵件地址 J
GUID 的值有 個字節與其它那些諸如 字節的整數相比要相對大一些這意味著如果在數據庫中使用 uniqueidentifier 鍵可能會帶來兩方面的消極影響存儲空間增大索引時間較慢
綜合來說 GUID 的優點帶來的便利遠超出其缺點帶來的影響隨著諸如 WebService 等系統互聯與整合技術的不斷發展其唯一標識的特性使得其應用越來越廣在您的應用程序中也應考慮使用它了
From:http://tw.wingwit.com/Article/program/net/201311/13985.html