csharp [Guid]
发布时间:2020-12-12 15:39:45 所属栏目:MsSql教程 来源:网络整理
导读:GUID(全局统一标识符)是指在一台机器上生成的数字,它保证对在同一时空中的所有机器都是唯一的。通常平台会提供生成GUID的API。生成算法很有意思,用到了以太网卡地址、纳秒级时间、芯片ID码和许多可能的数字。GUID的唯一缺陷在于生成的结果串会比较大。”
GUID(全局统一标识符)是指在一台机器上生成的数字,它保证对在同一时空中的所有机器都是唯一的。通常平台会提供生成GUID的API。生成算法很有意思,用到了以太网卡地址、纳秒级时间、芯片ID码和许多可能的数字。GUID的唯一缺陷在于生成的结果串会比较大。”
1.?????????一个GUID为一个128位的整数(16字节),在使用唯一标识符的情况下,你可以在所有计算机和网络之间使用这一整数。 ?2.?????????GUID?的格式为“xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx”,其中每个?x?是?0-9?或?a-f?范围内的一个十六进制的数字。例如:337c7f2b-7a34-4f50-9141-bab9e6478cc8?即为有效的?GUID?值。 3.?????????世界上(Koffer注:应该是地球上)的任何两台计算机都不会生成重复的?GUID?值。GUID?主要用于在拥有多个节点、多台计算机的网络或系统中,分配必须具有唯一性的标识符。 4.?????????在?Windows?平台上,GUID?应用非常广泛:注册表、类及接口标识、数据库、甚至自动生成的机器名、目录名等。 .NET中使用GUID? 当Windows开发人员需要一个唯一数值时,他们通常使用到一个全局唯一标识符(GUID,?Globally?Unique?Identifier)。微软采用GUID术语来表示这一唯一数值,而这一数值能够标识一个实体,比如一个Word文档。 ? ? 一个GUID为一个128位的整数(16字节),在使用唯一标识符的情况下,你可以在所有计算机和网络之间使用这一整数。 这一篇文章将解释.NET框架如何尽其最大潜力地为你建立自己的GUID。 你所看到的 GUIDs被用于整个Windows环境。当你在一个Windows系统中仔细阅读注册表时,你可以看到GUIDs被广泛用于唯一识别程序。特别地,它们作为程序的Ids集中在HKEY_CLASSES_ROOT部分(AppID键)。 这就是一个典型的GUID的格式: 936DA01F-9ABD-4d9d-80C7-02AF85C822A8? 在.NET中生成一个GUID 处理一个唯一标识符使得存储和获得信息变得更加容易。在处理一个数据库中这一功能变得尤其有用,因为一个GUID能够操作一个主键。 同样,SQL?Server也很好地集成了GUID的用途。SQL?Server数据类型uniqueidentifier能够存储一个GUID数值。你可以通过使用NEWID()函数在SQL?Server中生成这一数值,或者可以在SQL?Server之外生成GUID,然后再手动地插入这一数值。 在.NET中,后面一种方法显得更加直接。.NET?Framework中的基本System类包括GUID数值类型。除此之外,这一数值类型包含了处理GUID数值的方法。特别地,NewGUID方法允许你很容易地生成一个新的GUID。 ? ? 以下的C#命令行程序说明这一使用过程: using?System; namespace?DisplayGUID?{ class?GuidExample?{ static?void?Main(string[]?args)?{ GenerateGUID(); } static?void?GenerateGUID()?{ Console.WriteLine("GUID:?"?+?System.Guid.NewGuid().ToString()); }?}?}? 下面为这一程序的输出:(虽然不同系统之间的GUID是变化的。)? GUID:?9245fe4a-d402-451c-b9ed-9c1a04247482? 这里是使用VB.NET时的相同代码:? Module?BuilderExamples Sub?Main() GenerateGUID() End?Sub Public?Sub?GenerateGUID() Console.WriteLine("GUID:?"?+?System.Guid.NewGuid().ToString()) End?Sub End?Module? 这里是使用J#时的相同代码:? package?BuilderExamples; import?System.Console; public?class?GUIDExample?{ public?GUIDExample()?{?} public?static?void?main(String[]?args)?{ GenerateGUID(); } static?void?GenerateGUID()?{ Console.WriteLine("GUID:?"?+?System.Guid.NewGuid().ToString()); }?}? 以上范例使用到System.Guid空间名称的NewGuid函数来返回一个数值。(如果你在Visual?Basic中使用到这一代码,你应该感谢这一方法的简洁性。) 在这一点上,你可以看到GUID是一个很好的功能,但在程序的什么地方使用到它们,并如何使用它们? 在程序中使用一个GUID ? ? 一个GUID可以在后台数据库中操作一个主键。以下代码使用一个GUID在一个后台数据库中存储信息,这一数据库包含以下的列: pk_guid—uniqueidentifier数据类型? name—nvarchar数据类型? 这样出现一个包含文本框的简单Windows窗体。当选择按钮时,文本框中的数据被插入到数据库中。通过程序代码可以生成一个GUID并存储在其它列中: using?System; using?System.Drawing; using?System.Collections; using?System.ComponentModel; using?System.Windows.Forms; using?System.Data; ?using?Microsoft.ApplicationBlocks.Data;? namespace?GuidDBExampleCSharp?{ public?class?frmBuilderTest?:?Form????{ private?Label?lblName; private?TextBox?txtName; private?Button?btnInsert; private?Container?components?=?null; public?frmBuilderTest()????{ InitializeComponent(); } static?void?Main()?{ Application.Run(new?frmBuilderTest()); }? private?string?GenerateGUID()?{ return?System.Guid.NewGuid().ToString(); }? private?void?btnInsert_Click(object?sender,?System.EventArgs?e)?{ string?cs?=?"server=(local);Initial?Catalog=Northwind;Integrated Security=SSPI"; using?(?SqlConnection?conn?=?new?SqlConnection(cs)?)??{ try??{ string?sqlInsert?=?"INSERT?INTO?dbo.tblBuilderTest?(pk_guid,?[name])?VALUES?('" +?System.Guid.NewGuid().ToString()?+?"',?'"?+?txtName.Text?+?"')"; conn.Open(); SqlHelper.ExecuteNonQuery(conn,?CommandType.Text,?sqlInsert); }??catch(Exception?ex)??{ System.Console.Write("Error:?"?+?ex.Message); }??}??}??}??} 另一个GUID程序将一个唯一的标识符分配给一个.NET类或者接口,也就是说,GUID作为一个属性被分配给类或者接口。可以使用标准属性语法来实现这一过程: 我们可以扩展第一个范例来分配一个GUID。System.Runtime.InteropServices空间名称必须被引用来使用GUID属性。以下C#代码实现了这一过程: using?System; using?System.Runtime.InteropServices; namespace?DisplayGUID?{ [Guid("9245fe4a-d402-451c-b9ed-9c1a04247482")] class?GuidExample?{ static?void?Main(string[]?args)?{ GenerateGUID(); } static?void?GenerateGUID()?{ Console.WriteLine("GUID:?"?+?System.Guid.NewGuid().ToString()); }?}?} GUID永远是方便的 对于程序开发的各个方面,.NET?Framework简化了建立和处理GUID数值的过程。在.NET程序需要的地方,这一功能很容易地生成唯一的数值。 http://hingman.cnblogs.com/articles/99425.html(引自) (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- sql-server – T-SQL列出所有与登录数据库角色/权限的用户映
- DEV控件:gridControl常用属性设置
- sql – 我可以使用哪种算法来查找常见的相邻单词/模式识别?
- sql-server – 从Sql Server 2008 R2连接到IBM i服务器
- MSSqlServer新建查询不自动识别新建表
- MySQL 字符串模式匹配 扩展正则表达式模式匹配
- sql-server – 分区By和Group By之间的SQL Server性能比较
- 在Linux系统安装Mysql教程
- sql – 与VARCHAR()相比,BLOB或TEXT有多大差异?
- sql – 查找昨天的每个BUYER_ID的TOP 10最新记录