MSSQL - 用GUID值来完成数据表行标识

地址:http://www.cnblogs.com/huangfr/archive/2012/03/28/2420780.html

[Guid] [uniqueidentifier] NOT NULL CONSTRAINT [DF_Table_Guid_Guid]  DEFAULT (newid()),

  

以下的文章主要描述的是SQL Server数据表中使用GUID值来作为行标识,GUID(Global unique identifier)全局唯一标识符,GUID(Global unique identifier)是由网卡上的标识数字(每个网卡都有唯一的标识号)以及 CPU 时钟的唯一数字生成的的一个 16 字节的二进制值。
    
      GUID 的格式为“xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx”,其中每个 x 是 0-9 或 a-f 范围内的一个十六进制的数字。例如:6F9619FF-8B86-D011-B42D-00C04FC964FF 即为有效的 GUID 值。
    
      世界上的任何两台计算机都不会生成重复的SQL Server数据表中使用GUID 值。GUID 主要用于在拥有多个节点、多台计算机的网络或系统中,分配必须具有唯一性的标识符。在 Windows 平台上,GUID 应用非常广泛:注册表、类及接口标识、数据库、甚至自动生成的机器名、目录名等。
    
      在这次开发 ASP.NET 应用时,我大量使用了类型为 GUID 的 ID 列作为各实体表的关键字(键)。由于其唯一、易产生的特性,给应用程序处理带来诸多好处。
    
      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# 代码提前获得SQL Server数据表中使用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) 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 提供将SQL Server数据表中使用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 键,可能会带来两方面的消极影响:存储空间增大;索引时间较慢。
    
      综合来说, SQL Server数据表中使用GUID 的优点带来的便利远超出其缺点带来的影响,随着诸如 WebService 等系统互联与整合技术的不断发展,其唯一标识的特性使得其应用越来越广,在您的应用程序中也应考虑使用它了。

时间: 2024-11-08 12:42:06

MSSQL - 用GUID值来完成数据表行标识的相关文章

jquery easyui+sparkline插件+jqplot插件实现数据表行内插入线形图

Jquery easyui : 实现前端数据包格式化输出,支持多种模块式定义,只需要添加相应的预设参数即可实现丰富的前端. 资料参考: http://www.jeasyui.com/ Jquery sparkline: 基于jQuery 的js插件,底层调用html5的canvas标签,并通过js动态实现在数据表行内画条形图或趋势图,操作简单,可实现不同类型的图形化,如线形图,饼状图,柱形图. 资料参考:http://omnipotent.net/jquery.sparkline/#s-docs

查询数据表行数 然后循环查找表 添加数据到ITEMS

1 for( int i=0;i<tbBiao.Rows.Count;i++) 2 { 3 string TableName = (tbBiao.Rows[i]["Table"]).ToString(); 4 tbDn = GetAccessData(TableName); 5 DnList = tbDn.AsEnumerable().Select(p => p.Field<double>("DN").ToString()).Distinct

MySQL 数据表创建及管理

use stuinfo; -- 指定当前数据库 CREATE table if not exists student1( -- 创建数据表student1 sNo char(10) not NULL, sName varchar(20) not NULL, sex char(2), birthday DATE, deptName varchar(30), remark varchar(80) )engine=INNODB DEFAULT charset=utf8; -- 使用INNODB引擎 数

使用GUID作为数据表主键的好处(转)

http://blog.itpub.net/3875/viewspace-789520/ 分类: 数据库开发技术 使用GUID作为数据表主键的好处 [@[email protected]] 使用GUID作为数据表主键的好处 数据表主健通常采用以下三种方式: 1.         自动递增值. 2.         唯一名称.这个是使用自己定义的算法来生成一个唯一序列号. 3.         GUID(全局唯一标识符). GUID与自动递增值及唯一名称比较 GUID 在客户端生成,由GUID的特

MSSQL如何在没有主键的表中删除重复数据

为了对重复数据进行实验,下面建一个设计不太好(没有主键)表并插入了一些重复数据: create database testdb use testdb ; go create table DupsNoPK (Col1 int Null, Col2 char(5) Null ); go insert DupsNoPK(Col1,Col2) Values(1,'abc'), (2,'abc'), (2,'abc'), (2,'abc'), (7,'xyz'), (7,'xyz'); 为了验证表确实有重

验证一个值是否已经存在数据表中

前几天Insus.NET有写过一篇<angularjs自定义指令Directive>http://www.cnblogs.com/insus/p/6908815.html 仅是在程序中指定某些来值来匹配. 为你的数据表准备一个存储过程: 判断是否已经存在此值.只需写SELECT语句.如果没有记录返回,它将返回null. 有ASP.NET MVC程序中,创建model: 还要创建一个实体方法,是程序与数据协作与沟通的: 程序逻辑部分,还要写一个接口,供前端angularjs去读取: 返回给前端e

sql如何选取两个数据表中的值

一.直接在要选择的数据前面加上数据表的名字就行了 1 SELECT po.OrderID, p.LastName, p.FirstName 2 FROM Persons AS p, Product_Orders AS po 二.使用Join 1 SELECT Persons.LastName, Persons.FirstName, Orders.OrderNo 2 FROM Persons 3 INNER JOIN Orders 4 ON Persons.Id_P = Orders.Id_P 5

数据库中批量导入数据,有两列的值需要从其他表中查出来,我现在没有思路,求解惑

我现在批量往数据库里导正式数据(sql insert),但是数据中有三列分别是岗位,办事处,大区,给的数据中只给了岗位的值,办事处的值可以通过岗位值在岗位表查到,大区的值可以通过办事处的值在办事处表里查到.现在我已经把其他数据都导进去了,只剩办事处和大区没有值,我该如何批量更新这两列的值啊 导入的数据的表: 岗位表: 办事处表: 本人sql不是很好,希望sql大神能给出来解惑一下,拜谢~ 数据库中批量导入数据,有两列的值需要从其他表中查出来,我现在没有思路,求解惑 >> mysql 这个答案描

[Oracle]根据字段值全库搜索相关数据表和字段

这个需求比较冷门,但对于在某些特定的情况下,还是会有这样的需要的.好在Oracle实现还比较方便,用存储过程则轻松实现. 查询字符串: create or replace procedure search_string(pString in varchar) as cursor all_tab_cursor is select a.owner, a.table_name, b.column_name from dba_tables a, dba_tab_columns b, dba_object