成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

SQL Server數(shù)據(jù)表行標(biāo)識(shí)如何用GUID值來(lái)完成?

數(shù)據(jù)庫(kù) SQL Server
我們今天主要描述的是SQL Server數(shù)據(jù)表中使用GUID值來(lái)作為行標(biāo)識(shí),以及對(duì)其的作用的具體描述,以下就是文章的主要內(nèi)容講述。

以下的文章主要描述的是SQL Server數(shù)據(jù)表中使用GUID值來(lái)作為行標(biāo)識(shí),GUID(Global unique identifier)全局唯一標(biāo)識(shí)符,GUID(Global unique identifier)是由網(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ù)的SQL Server數(shù)據(jù)表中使用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è)表、類及接口標(biāo)識(shí)、數(shù)據(jù)庫(kù)、甚至自動(dòng)生成的機(jī)器名、目錄名等。

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

1、在 SQL Server 中使用 GUID

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

SQL Server 中的 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ù),如“INSERT INTO Table(ID,... ) VALUES(NewID(),...)”來(lái)生成此列的 GUID 值。

3)提前獲取 GUID 值

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

  1. SqlCommand cmd = New SqlCommand();  
  2. cmd.CommandText = "SELECT NewID()";  
  3. string rowID = (string) cmd.ExecuteScalar();  
  4. cmd.CommandText = "INSERT INTO Table(ID,...) VALUES(@ID,...)  
  5. cmd.Parameters.Add("@ID",SqlDbType.UniqueIdentifier).Value = new Guid(rowID);  
  6. cmd.ExecuteNoQuery(); 

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

2、在 .NET 中使用 GUID

GUID 在 .NET 中使用非常廣泛,而且 .NET Framework 提供了專門 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 的需要,.NET Framework 也提供了 SqlGUID 結(jié)構(gòu),它和 Guid 結(jié)構(gòu)類似,只是兩者對(duì)排序(CompareTo)的處理方式不同,SqlGuid 計(jì)算值的*** 6 個(gè)字節(jié)。而 Guid 計(jì)算全部 16 個(gè)字節(jié),這種差異可能會(huì)給 SQL Server 中 uniqueidentifier 列的排序帶來(lái)一定影響,當(dāng)然這種排序意義也不大。

.NET Framework 中可以使用類 GuidConverter 提供將SQL Server數(shù)據(jù)表中使用Guid 結(jié)構(gòu)與各種其他表示形式相互轉(zhuǎn)換的類型轉(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í),如類的 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ō), SQL Server數(shù)據(jù)表中使用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)考慮使用它了。

【編輯推薦】

  1. SQL Server刪除重復(fù)數(shù)據(jù)的2個(gè)實(shí)用方案
  2. SQL Server數(shù)據(jù)庫(kù)相關(guān)數(shù)據(jù)大匯和
  3. SQL Server Rollup關(guān)鍵字的使用竅門
  4. ASP調(diào)用SQL Server存儲(chǔ)過(guò)程的實(shí)際操作步驟
  5. SQL Server數(shù)據(jù)類型的25種有哪些?
責(zé)任編輯:佚名 來(lái)源: eNet硅谷動(dòng)力
相關(guān)推薦

2020-12-02 14:38:21

SQL數(shù)據(jù)庫(kù)MySQL

2010-07-16 09:06:51

SQL Server數(shù)

2010-07-19 13:15:39

SQL Server優(yōu)

2009-07-02 12:30:00

標(biāo)識(shí)值SQL Server

2020-02-28 15:33:12

代碼人工智能檢測(cè)

2010-07-22 10:30:36

SQL Server數(shù)

2009-09-07 16:13:14

LINQ to SQL

2010-06-18 11:04:39

SQL Server

2009-04-20 15:54:04

SQL Server重復(fù)行

2011-02-21 13:06:34

SQL Servr 2

2010-07-16 09:17:07

SQL Server

2010-10-19 17:09:27

sql server標(biāo)

2012-01-11 10:50:52

2017-05-31 14:55:19

2019-04-26 13:20:24

數(shù)據(jù)庫(kù)PostgreSQL Oracle

2009-07-17 17:41:25

JDBC連接SQL S

2015-07-20 17:05:38

SQL ServerNULL值

2010-09-16 14:38:55

Sql server表

2010-07-19 09:50:58

SQL Server2

2009-03-31 09:35:27

薩班斯奧克斯利法案數(shù)據(jù)行安全
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 亚洲一区视频在线 | 久久婷婷国产香蕉 | 亚洲午夜av | 久久久久久综合 | 中文字幕一区在线 | 高清一区二区视频 | 亚洲一区二区视频 | 九九伊人sl水蜜桃色推荐 | 欧美一级毛片久久99精品蜜桃 | 偷牌自拍 | 999观看免费高清www | 91精品一区二区三区久久久久 | 欧美aⅴ片 | 一级毛片免费 | 99国内精品久久久久久久 | 人人99| 日本免费视频 | 中文字幕国产精品 | 91视视频在线观看入口直接观看 | 99精品国产一区二区三区 | 99精品亚洲国产精品久久不卡 | 福利视频1000 | 夜夜骑综合| 久久成人精品一区二区三区 | 久久精品免费一区二区三 | 在线视频亚洲 | 一级欧美一级日韩片免费观看 | 在线观看黄色电影 | 午夜影院在线观看 | 欧美亚洲视频在线观看 | 成人午夜影院 | 国产精华一区 | 操久久| 色偷偷人人澡人人爽人人模 | 日韩 国产 在线 | 国产亚洲区 | 日韩成人av在线 | 久久久久国产一区二区三区 | 午夜视频在线播放 | 视频一区二区中文字幕 | 亚洲导航深夜福利涩涩屋 |