成人午夜激情影院,小视频免费在线观看,国产精品夜夜嗨,欧美日韩精品一区二区在线播放

在ASP.NET中創建和使用全球唯一標識符

2010-08-28 10:52:10來源:西部e網作者:

  全球唯一標識符由128位整數組成,你可以利用它進入任何一臺需要輸入唯一標識符的電腦或任何一個需要唯一標識符的網絡。Tony Patton講解了.NET Framework是怎樣教你創建自己的全球唯一標識符的。

  TechRepublic的free.NET時事通訊每周三刊發,在討論諸如網頁服務, ASP.NET, ADO.NET, 以及 Visual Studio .NET的問題時,里面舉出了一些有用的提示和編碼的例子。你現在就可以訂閱。

  當Windows的開發者們需要一個唯一值的時候,通常他們會用一個全球唯一標識符。微軟用全球唯一標識符這一述語來描述一個唯一的數字,它可以識別一個諸如Word文本之類的實體。

  一個全球唯一標識符由128位整數(16字節)組成,你可以利用它進入任何一臺需要輸入唯一標識符的電腦或任何一個需要唯一標識符的網 絡。這種類型的標識符被復制的可能性非常小。

  本文講解了.NET Framework怎樣幫你創建你自己的全球唯一標識符。

  無論在哪里,你都會看到全球唯一標識符總是在Windows環境中操作。當你在Windows系統中細讀注冊表時,你會發現全球唯一標識符被廣泛用來識別應用程序等等。在HKEY_CLASSES_ROOT中,它甚至被用作應用軟件的標識符。

  936DA01F-9ABD-4d9d-80C7-02AF85C822A8是一個典型的全球唯一標識符的格式。

  擁有一個全球唯一標識符就能更容易地存儲或重新找回信息。尤其當涉及到數據庫的時候,它的這一功能就顯得更為突出,這是因為全球唯一標識符可以幫助你設置一個絕好的主鍵。

  同樣,SQL Server也支持全球唯一標識符,它可以存儲一個uniqueidentifier數據類型的全球唯一標識符。你可以用NEWID()功能在SQL Server中設置一個標識符值,也可以在其它系統中設置標識符值然后再手動將該值插入SQL Server中。

  在.NET中后一種方法很直截了當。.NET Framework中的基本的系統類包括全球唯一標識符的值類型。此外,這個值類型中包括了使用全球唯一標識符值的方法。而NweGUID法則能讓你輕易地創建一個新的全球唯一標識符。

  創建起來也非常簡單:Guid tempId = Guid.NewGuid(); 這樣就可以了!


  用.NET創建一個全球唯一標識符

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

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

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

  1、在 SQL Server 中使用 GUID

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

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

  1) 作為列默認值

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

  2)使用 T-SQL

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

  3)提前獲取 GUID 值

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

  SqlCommand cmd = New SqlCommand();
  cmd.CommandText = "Select NewID()";
  string rowID = (string) cmd.ExecuteScalar();
  cmd.CommandText = "Insert INTO Table(ID,...) VALUES(@ID,...)
  cmd.Parameters.Add("@ID",SqlDbType.UniqueIdentifier).Value = new Guid(rowID);
  cmd.ExecuteNoQuery();

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

  2、在 .NET 中使用 GUID

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

  Guid 結構的常用法包括:

  1) System.Guid.NewGuid()()

  生成一個新的 GUID 唯一值

  2) Guid.ToString()

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

  3)構造函數 Guid(string)

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

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

  .NET Framework 中可以使用類 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 鍵,可能會帶來兩方面的消極影響:存儲空間增大;索引時間較慢。

關鍵詞:ASP.NET

贊助商鏈接:

主站蜘蛛池模板: 宣汉县| 上林县| 赤水市| 山东| 漳州市| 开原市| 论坛| 旺苍县| 大邑县| 安化县| 浮山县| 闸北区| 长宁区| 彰化市| 巴南区| 航空| 赣州市| 浦东新区| 图片| 思南县| 年辖:市辖区| 铁力市| 盈江县| 云阳县| 九江县| 嘉义市| 慈溪市| 孟州市| 连山| 二连浩特市| 墨竹工卡县| 房产| 阿城市| 文化| 横山县| 吉安县| 呼图壁县| 贺州市| 社旗县| 白玉县| 漯河市|