97超级碰碰碰久久久_精品成年人在线观看_精品国内女人视频免费观_福利一区二区久久

使用GUID值來(lái)作為數(shù)據(jù)庫(kù)行標(biāo)識(shí)的講解

時(shí)間:2022-06-27 05:10:07 數(shù)據(jù)庫(kù)操作系統(tǒng) 我要投稿
  • 相關(guān)推薦

關(guān)于使用GUID值來(lái)作為數(shù)據(jù)庫(kù)行標(biāo)識(shí)的講解

  GUID(Globaluniqueidentifier)全局唯一標(biāo)識(shí)符,它是由網(wǎng)卡上的標(biāo)識(shí)數(shù)字(每個(gè)網(wǎng)卡都有唯一的標(biāo)識(shí)號(hà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值。

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

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

  1、在SQLServer中使用GUID

  如果在SQLServer的表定義中將列類(lèi)型指定為uniqueidentifier,則列的值就為GUID類(lèi)型。

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

  1)作為列默認(rèn)值

  將uniqueidentifier的列的默認(rèn)值設(shè)為NewID(),這樣當(dāng)新行插入表中時(shí),會(huì)自動(dòng)生成此列GUID值。

  2)使用T-SQL

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

  3)提前獲取GUID值

  由于特殊功能需要,需要預(yù)先獲知新行的ID值,也可以使用如下C#代碼提前獲得GUID的值,再存儲(chǔ)到數(shù)據(jù)庫(kù)中:

  SqlCommandcmd=NewSqlCommand();

  cmd.CommandText="SELECTNewID()";

  stringrowID=(string)cmd.ExecuteScalar();

  cmd.CommandText="INSERTINTOTable(ID,...)VALUES(@ID,...)

  cmd.Parameters.Add("@ID",SqlDbType.UniqueIdentifier).Value=newGuid(rowID);

  cmd.ExecuteNoQuery();

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

  2、在.NET中使用GUID

  GUID在.NET中使用非常廣泛,而且.NETFramework提供了專(zhuān)門(mén)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可以為大寫(xiě),也可以為小寫(xiě),可以包含兩端的定界符“{}”或“()”,甚至可以省略中間的“-”,Guid結(jié)構(gòu)的構(gòu)造函數(shù)有很多,其它構(gòu)造用法并不常用。

  同時(shí),為了適用數(shù)據(jù)庫(kù)中使用GUID的需要,.NETFramework也提供了SqlGUID結(jié)構(gòu),它和Guid結(jié)構(gòu)類(lèi)似,只是兩者對(duì)排序(CompareTo)的處理方式不同,SqlGuid計(jì)算值的最后6個(gè)字節(jié)。而Guid計(jì)算全部16個(gè)字節(jié),這種差異可能會(huì)給SQLServer中uniqueidentifier列的排序帶來(lái)一定影響,當(dāng)然這種排序意義也不大。

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

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

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

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

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

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

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

  2)缺點(diǎn)

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

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

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

【使用GUID值來(lái)作為數(shù)據(jù)庫(kù)行標(biāo)識(shí)的講解】相關(guān)文章:

互聯(lián)網(wǎng)數(shù)據(jù)庫(kù)考點(diǎn)講解06-28

銀行卡發(fā)卡行標(biāo)識(shí)代碼及卡號(hào)以及磁條信息格式和使用07-03

用MySQL來(lái)創(chuàng)建數(shù)據(jù)庫(kù)和數(shù)據(jù)庫(kù)表06-28

新冰箱使用的注意事項(xiàng)講解07-03

銀行打印的工資清單能否作為證據(jù)使用?07-12

如何使用微信來(lái)賺錢(qián)?07-13

使用Java程序連接各種數(shù)據(jù)庫(kù)的方法07-01

關(guān)于使用Mixin設(shè)計(jì)模式進(jìn)行Python編程的方法講解06-29

如何使用騰訊手機(jī)管家來(lái)更新軟件07-13

作為一個(gè)攝影師如何更好的使用flickr?07-09