校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > 使用 GUID 值來作為數(shù)據(jù)庫行標(biāo)識講解

使用 GUID 值來作為數(shù)據(jù)庫行標(biāo)識講解

熱門標(biāo)簽:AI智能云呼電話機(jī)器人怎么注冊 商家地圖標(biāo)注圖片 怎么在高德地圖標(biāo)注多個(gè)點(diǎn) 福州外呼系統(tǒng)招商 四川穩(wěn)定外呼系統(tǒng)公司 電話機(jī)器人接口是什么樣的 百度地圖標(biāo)注信息怎么修改 溫州語音外呼系統(tǒng)排名 沈陽外呼系統(tǒng)有效果嗎
GUID(Global unique identifier)全局唯一標(biāo)識符,它是由網(wǎng)卡上的標(biāo)識數(shù)字(每個(gè)網(wǎng)卡都有唯一的標(biāo)識號)以及 CPU 時(shí)鐘的唯一數(shù)字生成的的一個(gè) 16 字節(jié)的二進(jìn)制值。

GUID 的格式為“xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx”,其中每個(gè) x 是 0-9 或 a-f 范圍內(nèi)的一個(gè)十六進(jìn)制的數(shù)字。例如:6F9619FF-8B86-D011-B42D-00C04FC964FF 即為有效的 GUID 值。

世界上的任何兩臺計(jì)算機(jī)都不會生成重復(fù)的 GUID 值。GUID 主要用于在擁有多個(gè)節(jié)點(diǎn)、多臺計(jì)算機(jī)的網(wǎng)絡(luò)或系統(tǒng)中,分配必須具有唯一性的標(biāo)識符。在 Windows 平臺上,GUID 應(yīng)用非常廣泛:注冊表、類及接口標(biāo)識、數(shù)據(jù)庫、甚至自動(dòng)生成的機(jī)器名、目錄名等。

在這次開發(fā) ASP.NET 應(yīng)用時(shí),我大量使用了類型為 GUID 的 ID 列作為各實(shí)體表的關(guān)鍵字(鍵)。由于其唯一、易產(chǎn)生的特性,給應(yīng)用程序處理帶來諸多好處。

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)新行插入表中時(shí),會自動(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ù)運(yùn)算,但可以進(jìn)行(意義不大的)比較操作和 NULL 檢查;它不能象 IDENTITY 列一樣,可以獲知每行的增加時(shí)間的先后順序,只能通過增加其它時(shí)間或時(shí)間戳列來完成此功能。

2、在 .NET 中使用 GUID

GUID 在 .NET 中使用非常廣泛,而且 .NET Framework 提供了專門 Guid 基礎(chǔ)結(jié)構(gòu)。

Guid 結(jié)構(gòu)的常用法包括:

1) Guid.NewGUID() 

生成一個(gè)新的 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í),為了適用數(shù)據(jù)庫中使用 GUID 的需要,.NET Framework 也提供了 SqlGUID 結(jié)構(gòu),它和 Guid 結(jié)構(gòu)類似,只是兩者對排序(CompareTo)的處理方式不同,SqlGuid 計(jì)算值的最后 6 個(gè)字節(jié)。而 Guid 計(jì)算全部 16 個(gè)字節(jié),這種差異可能會給 SQL Server 中 uniqueidentifier 列的排序帶來一定影響,當(dāng)然這種排序意義也不大。 

.NET Framework 中可以使用類 GuidConverter 提供將 Guid 結(jié)構(gòu)與各種其他表示形式相互轉(zhuǎn)換的類型轉(zhuǎn)換器。


3、GUID 的優(yōu)缺點(diǎn)

1) 優(yōu)點(diǎn)

同 IDENTITY 列相比,uniqueidentifier 列可以通過 NewID() 函數(shù)提前得知新增加的行 ID,為應(yīng)用程序的后續(xù)處理提供了很大方便。


便于數(shù)據(jù)庫移植,其它數(shù)據(jù)庫中并不一定具有 IDENTITY 列,而 Guid 列可以作為字符型列轉(zhuǎn)換到其它數(shù)據(jù)庫中,同時(shí)將應(yīng)用程序中產(chǎn)生的 GUID 值存入數(shù)據(jù)庫,它不會對原有數(shù)據(jù)帶來影響。


便于數(shù)據(jù)庫初始化,如果應(yīng)用程序要加載一些初始數(shù)據(jù), IDENTITY 列的處理方式就比較麻煩,而 uniqueidentifier 列則無需任何處理,直接用 T-SQL 加載即可。


便于對某些對象或常量進(jìn)行永久標(biāo)識,如類的 ClassID,對象的實(shí)例標(biāo)識,UDDI 中的聯(lián)系人、服務(wù)接口、tModel標(biāo)識定義等。
2) 缺點(diǎn)

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


GUID 的值有 16 個(gè)字節(jié),與其它那些諸如 4 字節(jié)的整數(shù)相比要相對大一些。這意味著如果在數(shù)據(jù)庫中使用 uniqueidentifier 鍵,可能會帶來兩方面的消極影響:存儲空間增大;索引時(shí)間較慢。

綜合來說, GUID 的優(yōu)點(diǎn)帶來的便利遠(yuǎn)超出其缺點(diǎn)帶來的影響,隨著諸如 WebService 等系統(tǒng)互聯(lián)與整合技術(shù)的不斷發(fā)展,其唯一標(biāo)識的特性使得其應(yīng)用越來越廣,在您的應(yīng)用程序中也應(yīng)考慮使用它了。

標(biāo)簽:邯鄲 無錫 營口 汕尾 西寧 來賓 寶雞 七臺河

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《使用 GUID 值來作為數(shù)據(jù)庫行標(biāo)識講解》,本文關(guān)鍵詞  使用,GUID,值,來,作為,數(shù)據(jù)庫,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《使用 GUID 值來作為數(shù)據(jù)庫行標(biāo)識講解》相關(guān)的同類信息!
  • 本頁收集關(guān)于使用 GUID 值來作為數(shù)據(jù)庫行標(biāo)識講解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 家居| 玉田县| 海城市| 浠水县| 庄浪县| 咸宁市| 枣庄市| 郯城县| 禄丰县| 边坝县| 高阳县| 毕节市| 衡水市| 洛扎县| 桐柏县| 伽师县| 阿图什市| 铅山县| 聂拉木县| 马尔康县| 秭归县| 北票市| 遂宁市| 昂仁县| 锡林郭勒盟| 岱山县| 利津县| 铜陵市| SHOW| 普格县| 登封市| 临邑县| 萝北县| 额尔古纳市| 丘北县| 越西县| 东阳市| 博爱县| 色达县| 灵丘县| 铜陵市|