国产精品一久久香蕉产线看-国产精品一区在线播放-国产精品自线在线播放-国产毛片久久国产-一级视频在线-一级视频在线观看免费

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

  • 相關(guān)推薦

關(guān)于使用GUID值來作為數(shù)據(jù)庫行標識的講解

  GUID(Globaluniqueidentifier)全局唯一標識符,它是由網(wǎng)卡上的標識數(shù)字(每個網(wǎng)卡都有唯一的標識號)以及CPU時鐘的唯一數(shù)字生成的的一個16字節(jié)的二進制值。

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

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

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

  1、在SQLServer中使用GUID

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

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

  1)作為列默認值

  將uniqueidentifier的列的默認值設為NewID(),這樣當新行插入表中時,會自動生成此列GUID值。

  2)使用T-SQL

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

  3)提前獲取GUID值

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

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

  2、在.NET中使用GUID

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

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

  1)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的需要,.NETFramework也提供了SqlGUID結(jié)構(gòu),它和Guid結(jié)構(gòu)類似,只是兩者對排序(CompareTo)的處理方式不同,SqlGuid計算值的最后6個字節(jié)。而Guid計算全部16個字節(jié),這種差異可能會給SQLServer中uniqueidentifier列的排序帶來一定影響,當然這種排序意義也不大。

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

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

  1)優(yōu)點

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

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

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

  便于對某些對象或常量進行永久標識,如類的ClassID,對象的實例標識,UDDI中的聯(lián)系人、服務接口、tModel標識定義等。

  2)缺點

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

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

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

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

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

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

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

新冰箱使用的注意事項講解07-03

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

如何使用微信來賺錢?07-13

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

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

如何使用騰訊手機管家來更新軟件07-13

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

主站蜘蛛池模板: 日本黄色的视频 | 亚洲视频一区二区三区 | 成人国产免费 | 亚洲免费在线视频观看 | 女人色极影院 | 久久久国产精品网站 | 午夜成私人影院在线观看 | 女性爽爽影院免费观看麻豆 | 九九精品视频一区在线 | 国产第一区二区三区在线观看 | 在线观着免费观看国产黄 | 欧美性xxxxxx性 | 国产老师制服丝袜裤视频 | www.99视频| 久久中文字幕制服丝袜美腿 | 免费一级黄色 | 午夜视频色 | 爆操在线 | 亚欧美图片自偷自拍另类 | 色片免费在线观看 | 日黄网站 | 小明看国产 | sis人成在线视频 | 国产bbwbbwbbwbbw | 国产精品日韩在线观看 | 亚洲免费一区二区 | 337p色噜噜人体大胆欧美 | 一级特黄aa大片免费 | 国产成人在线视频观看 | 无边泳池在线观看 | 亚洲国产成人va在线观看 | 国产精品久久久久久久y | 亚洲国产精品网站久久 | 51视频在线| 日韩精品一区二区三区不卡 | 日本视频免费高清一本18 | 欧美日韩一区二区三区四区 | 国产麻豆精品免费视频 | 白洁的性荡生活全文 | 麻豆精品在线观看 | 欧美性xxxxx极品视频 |