黄色国产视频,男女啪啪18禁无遮挡激烈,久草热8精品视频在线观看,四虎国产精品永久在线下载

            使用GUID值來作為數據庫行標識的講解

            時間:2022-06-27 05:10:07 數據庫操作系統 我要投稿
            • 相關推薦

            關于使用GUID值來作為數據庫行標識的講解

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

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

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

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

              1、在SQLServer中使用GUID

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

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

              1)作為列默認值

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

              2)使用T-SQL

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

              3)提前獲取GUID值

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

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

              2、在.NET中使用GUID

              GUID在.NET中使用非常廣泛,而且.NETFramework提供了專門Guid基礎結構。

              Guid結構的常用法包括:

              1)Guid.NewGUID()

              生成一個新的GUID唯一值

              2)Guid.ToString()

              將GUID值轉換成字符串,便于處理

              3)構造函數Guid(string)

              由string生成Guid結構,其中string可以為大寫,也可以為小寫,可以包含兩端的定界符“{}”或“()”,甚至可以省略中間的“-”,Guid結構的構造函數有很多,其它構造用法并不常用。

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

              .NETFramework中可以使用類GuidConverter提供將Guid結構與各種其他表示形式相互轉換的類型轉換器。

              3、GUID的優缺點

              1)優點

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

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

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

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

              2)缺點

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

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

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

            【使用GUID值來作為數據庫行標識的講解】相關文章:

            互聯網數據庫考點講解06-28

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

            用MySQL來創建數據庫和數據庫表06-28

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

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

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

            使用Java程序連接各種數據庫的方法07-01

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

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

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

            主站蜘蛛池模板: 久久99国产精品视频| 精品亚洲视频在线| 国内精品国内精品自线一二三区| 中文字幕人成乱码熟女app| 免费网站视频在线观看| 国产激情综合| 欧美成人精品一区二区综合| 性xxxx欧美老妇胖老太269| 91嫩草香蕉| 欧美在线亚洲| 欧美大片一区二区三区| 欧美成本人视频免费播放| 午夜美女裸体福利视频| avtt成人| 青青草精品在线视频| 欧美在线一级视频| 国产成人综合在线女婷五月99播放| 国产在线精品一区二区不卡麻豆| aa视频在线播放| 任你干精品| 欧美入口| 中文字幕无码免费久久99| 久久久久久午夜成人影院| 91国精品人一区二区三区| 欧美日韩精品影院| 激情欧美日韩| 中文字幕无码日韩专区免费 | 久久精品视频在线观看| 在线三级网址| 国产精品毛片一区视频播| 日韩av片无码一区二区三区不卡 | 天天曰夜夜| 99热这里精品| 国产女人抽搐喷浆视频| 国产又粗又硬又大爽黄老大爷| 成人aaaaa片毛片按摩| 日韩精品免费| 日本迷妹网在线观看| 毛片大全真人在线| 色欲久久人妻内射| 日本熟妇色一本在线视频|