使用 GUID 值來作為資料庫行標識

2021-04-12 12:10:06 字數 2684 閱讀 8615

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

guid 的格式為「******xx-***x-***x-***x-************」,其中每個 x 是 0-9 或 a-f 範圍內的乙個十六進製制的數字。例如:6f9619ff-8b86-d011-b42d-00c04fc964ff 即為有效的 guid 值。

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

在這次開發 asp.net 應用時,我大量使用了型別為 guid 的 id 列作為各實體表的關鍵字(鍵)。由於其唯

一、易產生的特性,給應用程式處理帶來諸多好處。

1、在 sql server 中使用 guid

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

sql server 中的 newid() 函式可以產生 guid 唯一值,使用此函式的幾種方式如下:

1) 作為列預設值

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

2)使用 t-sql

在 t-sql 中使用 newid()函式,如「insert into table(id,... 

values(newid(),...)」來生成此列的 guid 值。

3)提前獲取 guid 值

由於特殊功能需要,需要預先獲知新行的 id 值,也可以使用如下 c# **提前獲得 guid 的值,再儲存到資料庫中:

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

2、在 .net 中使用 guid

guid 在 .net 中使用非常廣泛,而且 .net framework 提供了專門 guid 基礎結構。

guid 結構的常用法包括:

1) guid.newguid() 

生成乙個新的 guid 唯一值

2) guid.tostring()

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

3)建構函式 guid(string) 

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

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

.net framework 中可以使用類 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 等系統互聯與整合技術的不斷發展,其唯一標識的特性使得其應用越來越廣,在您的應用程式中也應考慮使用它了。

使用 GUID 值來作為資料庫行標識

guid global unique identifier 全域性唯一識別符號,它是由網絡卡上的標識數字 每個網絡卡都有唯一的標識號 以及 cpu 時鐘的唯一數字生成的 的乙個 16 位元組的二進位制值。guid 的格式為 xx x x x 其中每個 x 是 0 9 或 a f 範圍內的乙個十六進製...

使用GUID作為資料庫主鍵的測試

今天聽了msdn的webcast,是關於entlib的資料訪問的講座,末尾我問了兩個自己所關心的問題 在乙個較大型的應用中,如果需要用到兩套以上的資料庫 如 sql server和oracle 是否可以把需要的sql查詢全部封裝在儲存過程裡,這樣就只需要一套訪問 了,有沒有更好的方法解決這個問題?在...

使用GUID作為資料庫主鍵的測試

今天聽了msdn的webcast,是關於entlib的資料訪問的講座,末尾我問了兩個自己所關心的問題 在乙個較大型的應用中,如果需要用到兩套以上的資料庫 如 sql server和oracle 是否可以把需要的sql查詢全部封裝在儲存過程裡,這樣就只需要一套訪問 了,有沒有更好的方法解決這個問題?在...