人妖在线一区,国产日韩欧美一区二区综合在线,国产啪精品视频网站免费,欧美内射深插日本少妇

新聞動(dòng)態(tài)

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

發(fā)布日期:2022-02-03 18:28 | 文章來源:腳本之家
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、在SQLServer中使用GUID 如果在SQLServer的表定義中將列類型指定為uniqueidentifier,則列的值就為GUID類型。 SQLServer中的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ù),如“INSERTINTOTable(ID,...)VALUES(NewID(),...)”來生成此列的GUID值。 3)提前獲取GUID值 由于特殊功能需要,需要預(yù)先獲知新行的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值不能進(jìn)行算術(shù)運(yùn)算,但可以進(jìn)行(意義不大的)比較操作和NULL檢查;它不能象IDENTITY列一樣,可以獲知每行的增加時(shí)間的先后順序,只能通過增加其它時(shí)間或時(shí)間戳列來完成此功能。 2、在.NET中使用GUID GUID在.NET中使用非常廣泛,而且.NETFramework提供了專門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的需要,.NETFramework也提供了SqlGUID結(jié)構(gòu),它和Guid結(jié)構(gòu)類似,只是兩者對排序(CompareTo)的處理方式不同,SqlGuid計(jì)算值的最后6個(gè)字節(jié)。而Guid計(jì)算全部16個(gè)字節(jié),這種差異可能會給SQLServer中uniqueidentifier列的排序帶來一定影響,當(dāng)然這種排序意義也不大。 .NETFramework中可以使用類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)考慮使用它了。

海外服務(wù)器租用

版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。

實(shí)時(shí)開通

自選配置、實(shí)時(shí)開通

免備案

全球線路精選!

全天候客戶服務(wù)

7x24全年不間斷在線

專屬顧問服務(wù)

1對1客戶咨詢顧問

在線
客服

在線客服:7*24小時(shí)在線

客服
熱線

400-630-3752
7*24小時(shí)客服服務(wù)熱線

關(guān)注
微信

關(guān)注官方微信
頂部