GUID在.net里的使用

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

GUID 在 .NET 中使用非常广泛,而且 .NET Framework 提供了专门 Guid 基础结构。

Guid 结构的常用法包括:

1) Guid.NewGUID()

生成一个新的 GUID 唯一值

2) Guid.ToString()

将 GUID 值转换成字符串,便于处理

3)构造函数 Guid(string)

由 string 生成 Guid 结构,其中string 可以为大写,也可以为小写,可以包含两端的定界符“{}”或“()”,甚至可以省略中间的“-”,Guid 结构的构造函数有很多,其它构造用法并不常用。

.NET Framework 中可以使用类 GuidConverter 提供将 Guid 结构与各种其他表示形式相互转换的类型转换器。

在C#中生成一个GUID

处理一个唯一标识符使得存储和获得信息变得更加容易。在处理一个数据库中这一功能变得尤其有用,因为一个GUID能够操作一个主键。

同样,SQL Server也很好地集成了GUID的用途。SQL
Server数据类型uniqueidentifier能够存储一个GUID数值。你可以通过使用NEWID()函数在SQL
Server中生成这一数值,或者可以在SQL Server之外生成GUID,然后再手动地插入这一数值。

在.NET中,后面一种方法显得更加直接。.NET Framework中的基本System类包括GUID数值类型。除此之外,这一数值类型包含了处理GUID数值的方法。特别地,NewGUID方法允许你很容易地生成一个新的GUID。

using System;
namespace DisplayGUID
{
    class Program
    {
        static void Main(string[] args)
        {
            GenerateGUID();
        }
        static void GenerateGUID()
        {
            Console.WriteLine("GUID:" + System.Guid.NewGuid().ToString());
        }
    }
}

下面为这一程序的输出:(虽然不同系统之间的GUID是变化的。)

GUID: 9245fe4a-d402-451c-b9ed-9c1a04247482

以上范例使用到System.Guid空间名称的NewGuid函数来返回一个数值。在这一点上,你可以看到GUID是一个很好的功能,但在程序的什么地方使用到它们,并如何使用它们?

在程序中使用一个GUID

一个GUID可以在后台数据库中操作一个主键。以下代码使用一个GUID在一个后台数据库中存储信息,这一数据库包含以下的列:

pk_guid  —uniqueidentifier  数据类型

name      —nvarchar  数据类型

这样出现一个包含文本框的简单Windows窗体。当选择按钮时,文本框中的数据被插入到数据库中name列。通过程序代码可以生成一个GUID并存储在pk_guid列中:

 using System;
 using System.Collections.Generic;
 using System.ComponentModel;
 using System.Data;
 using System.Drawing;
 using System.Linq;
 using System.Text;
 using System.Windows.Forms;
 using System.Data.SqlClient;

namespace GuidSqlDBExample
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

        private void btnInsert_Click(object sender, EventArgs e)
        {
            string _str = "server=(local);Initial Catalog=TestGuid;Integrated Security=SSPI";
            using (SqlConnection conn = new SqlConnection(_str))
            {
                try
                {
                    string _sqlInsert = "INSERT INTO dbo.Guid(pk_guid, name) VALUES (‘"+ System.Guid.NewGuid().ToString() + "‘, ‘" + txtName.Text + "‘)";
                    conn.Open();
                    SqlCommand _cmd = new SqlCommand(_sqlInsert, conn);
                    _cmd.ExecuteNonQuery();
                }
                catch (Exception ex)
                {
                    System.Console.Write("Error: " + ex.Message);
                }
            }
        }
    }

}

另一个GUID程序将一个唯一的标识符分配给一个.NET类或者接口,也就是说,GUID作为一个属性被分配给类或者接口。可以使用标准属性语法来实现这一过程: 本

我们可以扩展第一个范例来分配一个GUID。System.Runtime.InteropServices空间名称必须被引用来使用GUID属性。以下C#代码实现了这一过程:

 using System;
 using System.Collections.Generic;
 using System.Linq;
 using System.Text;
 using System.Runtime.InteropServices; 

 namespace GuidTest
 {
     [Guid("9245fe4a-d402-451c-b9ed-9c1a04247482")]
    class Program
    {
        static void Main(string[] args)
        {
            GenerateGUID();
        }
        static void GenerateGUID()
        {
            Console.WriteLine("GUID:" + System.Guid.NewGuid().ToString());
        }
    }
}

GUID永远是方便的

对于程序开发的各个方面,.NET Framework简化了建立和处理GUID数值的过程。在.NET程序需要的地方,这一功能很容易地生成唯一的数值。

Example:

 static void Main(string[] args)
        {
            //使用NewGuid静态方法,得到一个guid的新实例
            System.Guid guid = System.Guid.NewGuid();
            System.Console.WriteLine(guid.ToString()); 

            //
            // 相等运算符和不等运算符是Guid结构自己的运算符,不要和运算符"=="、"!="弄混
            //

            System.Guid guid2 = guid;
            if(guid == guid2)//使用相等运算符判断两个guid是否相等
            {
                System.Console.WriteLine(guid.ToString() + "等于" + guid2.ToString());
            }

            guid2 = System.Guid.NewGuid();
            if(guid != guid2)//使用相等运算符判断两个guid是否不等
            {
                System.Console.WriteLine(guid.ToString() + "不等于" + guid2.ToString());
            }

            System.Console.ReadLine();
        }

时间: 2024-10-07 21:55:53

GUID在.net里的使用的相关文章

项目问题总结2:GUID区分大写和小写吗?

问题描写叙述: 近期在做项目的过程中,遇到一个问题,将从基础系统查询出来的课程ID作为參数去考评系统里查询考试信息,却什么也查不出来,调试了半天不知道什么原因. 问题分析: 静下心来思考一下,能够肯定程序代码逻辑以及实现是没有问题的,因此就是数据的问题了.那么数据出问题就应该是数据库的问题了,在进行单步调试的过程中.去检查各个变量以及參数的值,最终找到了问题出在哪里.先来看看两个系统的数据库存储CourseId的数据类型是什么吧,例如以下图: 上图中左边是基础的.右边是考试的.再来看看我的代码是

项目问题总结2:GUID区分大小写吗?

问题描述: 最近在做项目的过程中,遇到一个问题,将从基础系统查询出来的课程ID作为参数去考评系统里查询考试信息,却什么也查不出来,调试了半天不知道什么原因. 问题分析: 静下心来思考一下,可以肯定程序代码逻辑以及实现是没有问题的,因此就是数据的问题了.那么数据出问题就应该是数据库的问题了,在进行单步调试的过程中,去检查各个变量以及参数的值,终于找到了问题出在哪里,先来看看两个系统的数据库存储CourseId的数据类型是什么吧,如下图: 上图中左边是基础的,右边是考试的.再来看看我的代码是如何实现

C#开发ActiveX控件

昨天写了篇博客<Winform 程序嵌入WPF程序 并发送消息>,没有说明为什么要嵌入WPF程序,那么今天就来唠叨唠叨其中的一个使用场景,开发ActiveX控件 首先,新建一个类库工程HuaYun.ActiveX,右键工程属性,在“应用程序”页,点击“程序集信息”按钮,在弹出的窗体里勾选“使程序集COM可见”,具体操作如下图 第二步,切换到“生成”的选项卡,勾选“为COM互操作注册”,如下图 第三步,在AssemblyInfo.cs里添加[assembly: AllowPartiallyTru

Windows Docker的有趣事实

本文最初发表于华来四公众号,请扫描以下二维码关注.给盆盆发微信(微信号:markpah),即可要求加入Windows Docker微信群.或者微软混合云微信群. 众所周知,Docker能打通开发和运维的任督二脉,所谓DevOps是也.有朋友说,这符合王阳明的"知行合一"之教. 而Windows Server 2016 TP4内置的Windows Docker亦已经出来一段时间,这里就来和诸公汇报一下测试结果. Linux和Windows,容器里各有多少进程? 在安装配置Containe

C#里System.Data.SQLite中对GUID的处理

string sqlstring = "select * from endpoint_policy where HEX([UserGuid]) ='" + CommonHelper.ConvertGuid(uguid) + "'"; var query = db.Database.SqlQuery<endpoint_policy>(sqlstring).AsQueryable(); var endpoint_policy = new PagedList&

[NHibernate] Guid 作主键速度超慢的背后

http://blog.csdn.net/educast/article/details/6602353 最近遇到了一个让人抓狂的性能问题.生产环境里有一张表的数据量目前达到了 70 万条.结果发现无论是匹配主键的查询还是更新,执行一条语句居然需要 3.5 秒!如果把 NH Prof 中截获的 SQL 语句拿到 PL/SQL Developer 里执行,就只需几十毫秒.一开始还以为是NH的问题,后来发现其实另有隐情. 介绍一下环境先.数据库使用 Oracle10g,所有字符类型的字段都是 var

EF里的继承映射关系TPH、TPT和TPC的讲解以及一些具体的例子

EF里的继承映射关系TPH.TPT和TPC的讲解以及一些具体的例子 本章节讲解EF里的继承映射关系,分为TPH.TPT.TPC.具体: 1.TPH:Table Per Hierarchy 这是EF的默认的继承映射关系:一张表存放基类和子类的所有列,自动生成的discriminator列用来区分基类和子类的数据.新建一个度假村Resort实体类试试: /// <summary> /// 度假村类 /// </summary> public class Resort : Lodging

EF里单个实体的增查改删以及主从表关联数据的各种增删 改查

本文目录 EF对单个实体的增查改删 增加单个实体 查询单个实体 修改单个实体 删除单个实体 EF里主从表关联数据的各种增删改查 增加(增加从表数据.增加主从表数据) 查询(根据主表找从表数据.根据从表找主表数据) 修改(修改从表的外键) 删除(删除主从表关系.删除主表数据.删除主从表数据.修改从表数据外键) 补充内容 SaveChanges方法提交多次操作 DbSet.Add方法返回当前实体 源码和系列文章导航 注:本章节多次演示了各种删除,要重复查看效果,需要解开注释初始化数据方法. 一.EF

PHP下生成非重复的guid

PHP在多进程运行的情况下,如果不采用内存锁或者文件锁,基本没办法能解决生成唯一Id的问题.试过了静态变量.单例模式等等.查询到php里的uniqid()函数,最后还是找到了一个折中方式,虽然还是有可能出现重复的id,基本上可以在忍受访问内,唯一不好就是id没有任何规律. /** * 获取唯一的guid * @return string 32位字符串 */ public static function get_md5_id(){ return md5(uniqid("", true))