下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
精品文檔推薦求知若饑,虛心若愚。第2頁/共2頁學(xué)而不舍,金石可鏤。第關(guān)于使用GUID值來作為數(shù)據(jù)庫行標(biāo)識的講解關(guān)于使用GUID值來作為數(shù)據(jù)庫行標(biāo)識的講解
GUID(Globaluniqueidentifier)全局唯一標(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、在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供應(yīng)了特地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也供應(yīng)了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供應(yīng)將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ù)處理供應(yīng)了很大便利。
便于數(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í)間較慢。
綜合來說,G
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 二零二五年度家政服務(wù)業(yè)與洗衣店深度合作合同2篇
- 二零二五年度房屋租賃裝修保證金合同范本3篇
- 二零二五年度海洋工程設(shè)備安裝與維護(hù)合同6篇
- 二零二五年度水上交通安全評價(jià)與船舶安全檢驗(yàn)合同3篇
- 二零二五年度房產(chǎn)抵押個(gè)人養(yǎng)老貸款合同3篇
- 二零二五年度國畫收藏品鑒定與買賣合同3篇
- 環(huán)形運(yùn)動(dòng)器材及課程設(shè)計(jì)
- 海南職業(yè)技術(shù)學(xué)院《對外漢語教育學(xué)引論》2023-2024學(xué)年第一學(xué)期期末試卷
- 二零二五年度區(qū)塊鏈技術(shù)應(yīng)用合同條款與數(shù)字資產(chǎn)交易規(guī)則3篇
- 2025版建筑工程安全防護(hù)股份制合作協(xié)議書3篇
- 2023-2024學(xué)年甘肅省嘉峪關(guān)市酒鋼三中高三上數(shù)學(xué)期末學(xué)業(yè)質(zhì)量監(jiān)測試題含解析
- 水利機(jī)械施工方案
- 懸挑式腳手架驗(yàn)收記錄表
- 主變壓器試驗(yàn)報(bào)告模板
- 電動(dòng)叉車安全操作規(guī)程
- 靜鉆根植樁施工組織設(shè)計(jì)
- 工程精細(xì)化管理
- 柴油供貨運(yùn)輸服務(wù)方案
- 2022年長春市中小學(xué)教師筆試試題
- 肉牛肉羊屠宰加工項(xiàng)目選址方案
- 清洗劑msds清洗劑MSDS
評論
0/150
提交評論