SqlServer中的数据类型UniqueIdentifier

摘要:
所有列约束和属性都同意用于uniqueidentifier数据类型。应用程序API函数和方法返回的唯一标识符是使用客户端上的网卡生成的。当多行引用源表中的同一主键时,引用其他表的uniqueidentifier主键的外键列将包含多次出现的单个uniqueidentificationr值。ROWGUIDCOL属性表示此列的唯一标识符值唯一标识表中的行。uniqueidentifier数据类型的主要优点是确保Transact-SQLNEWID函数或应用程序GUID函数生成的值是全局唯一的。无法确定uniqueidentifier值的生成顺序。uniqueidentifier数据类型有16个字节,与其他整数(如4个字节)相比,它相对较大。
SqlServer中的数据类型UniqueIdentifier究竟是什么东东?

该类型一般用来做为主键使用,可用SQL语法的newid()来生成一个唯一的值。
我想请问的是,这个值是一个长整型的数据值呢,还是个其他的什么值?我在程序中该怎样去控制他?
欢迎多多交流。
 
 
 

摘自帮助:

uniqueidentifier
全局唯一标识符 (GUID)。

凝视
uniqueidentifier 数据类型的列或局部变量可用两种方法初始化为一个值: 

使用 NEWID 函数。


将字符串常量转换为例如以下形式(xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx,当中每一个 x 是 0-9 或 a-f 范围内的一个十六进制的数字)。比如,6F9619FF-8B86-D011-B42D-00C04FC964FF 即为有效的 uniqueidentifier 值。 
比較运算符可与 uniqueidentifier 值一起使用。然而,排列并非通过比較两个值的位模式来实现。同意对 uniqueidentifier 值运行的操作仅仅有比較 (=, <>, <, >, <=, >=) 和检查 NULL(IS NULL 和 IS NOT NULL)。不同意使用其他算术运算符。全部的列约束及属性(IDENTITY 除外)均同意用于 uniqueidentifier 数据类型。 


使用 uniqueidentifier 数据
uniqueidentifier 数据类型存储 16 字节的二进制值,该值的使用与全局唯一标识符 (GUID) 一样。GUID 是一个唯一的二进制数字;世界上的不论什么两台计算机都不会生成反复的 GUID 值。GUID 主要用于在拥有多个节点、多台计算机的网络中,分配必须具有唯一性的标识符。

uniqueidentifier 列的 GUID 值通常由下面方式获得: 

在 Transact-SQL 语句、批处理或脚本中调用 NEWID 函数。


在应用程序代码中,调用返回 GUID 值的应用程序 API 函数或方法。 
Transact-SQL NEWID 函数以及应用程序 API 函数和方法从它们网卡上的标识数字以及 CPU 时钟的唯一数字生成新的 uniqueidentifier 值。每一个网卡都有唯一的标识号。由 NEWID 返回的 uniqueidentifier 使用server上的网卡生成。由应用程序 API 函数和方法返回的 uniqueidentifier 使用客户机上的网卡生成。

一般不将 uniqueidentifier 定义为常量,由于非常难保证实际创建的 uniqueidentifier 具有唯一性。指定 uniqueidentifier 常量的方法有两种: 

字符串格式 
'6F9619FF-8B86-D011-B42D-00C04FC964FF'

二进制格式 
0xff19966f868b11d0b42d00c04fc964ff

uniqueidentifier 数据类型不象IDENTITY 属性那样为新插入的行自己主动生成新的ID。为了得到新的 uniqueidentifier 值,表必须具有一个指定 NEWID 函数的 DEFAULT 子句,或使用 NEWID 函数的 INSERT 语句:

CREATE TABLE MyUniqueTable
(UniqueColumn UNIQUEIDENTIFIER DEFAULT NEWID(),
Characters VARCHAR(10) )
GO
INSERT INTO MyUniqueTable(Characters) VALUES ('abc')
INSERT INTO MyUniqueTable VALUES (NEWID(), 'def')
GO

uniqueidentifier 列能够包括多次出现的 uniqueidentifier 值,除非也对此列指定了 UNIQUE 或 PRIMARY KEY 约束。当有多行引用源表中的同一主键时,引用其他表的 uniqueidentifier 主键的外键列将包括多次出现的个别 uniqueidentifier 值。

一个表能够有多个 uniqueidentifier 列。每一个表中能够指定一个具有 ROWGUIDCOL 属性的 uniqueidentifier 列。ROWGUIDCOL 属性表明此列的 uniqueidentifier 值唯一地标识表中的行。可是,该属性并没有运行该唯一性。唯一性必须通过其他机制来运行,比方为列指定 PRIMARY KEY 约束。ROWGUIDCOL 属性主要用于 SQL Server 复制。

uniqueidentifier 数据类型的主要长处是保证由 Transact-SQL NEWID 函数或应用程序 GUID 函数生成的值在全球是唯一的。

uniqueidentifier 数据类型的具有几个缺点: 

值长且难懂。这使用户难以正确键入它们,并且更难记住。


这些值是随机的,并且它们不能接受不论什么使它们对用户变得更有意义的模式。


没有不论什么方式能够决定生成 uniqueidentifier 值的顺序。它们不适用于那些依赖递增的键值的现有应用程序。


uniqueidentifier 数据类型具有 16 个字节,与其他那些诸如 4 字节的整数相比要相对大一些。这意味着使用 uniqueidentifier 键建立的索引可能会比使用 int 键实现的索引相对慢一些。 
假设全局唯一性并非必须的,或者须要一个连续递增的键,则能够考虑使用 IDENTITY 属性。


^_^
 
 

1。sql server帮助里面有具体的答案,自己查找。
2。打开帮助
索引--输入uniqueidentifier就可以。

 
 

uniqueidentifier是全局唯一标识符 (GUID)
NEWID()返回类型为uniqueidentifier
SQL SERVER联机帮助中的样例:
declare @myid uniqueidentifier
set @myid=newid()
print 'Value of @myid is '+cast(@myid as varchar(255))
每次执行以上程序返回不同的uniqueidentifier
 

免责声明:文章转载自《SqlServer中的数据类型UniqueIdentifier》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇Qt StyleSheet样式表实例(转)RK3288 GMAC整理下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

SQL Server 2005/2008 导入导出数据常见报错

数据库导入导出时总失败,错误信息如下: 正在验证 (错误) 消息 错误 0xc0202049: 数据流任务 1: 无法在只读列“ID”中插入数据。  (SQL Server 导入和导出向导)   错误 0xc0202045: 数据流任务 1: 验证列元数据失败。  (SQL Server 导入和导出向导)   错误 0xc004706b: 数据流任务 1:...

SQL SERVER的锁机制(三)——概述(锁与事务隔离级别)

五、锁与事务隔离级别 事务隔离级别简单的说,就是当激活事务时,控制事务内因SQL语句产生的锁定需要保留多入,影响范围多大,以防止多人访问时,在事务内发生数据查询的错误。设置事务隔离级别将影响整条连接。 SQL Server 数据库引擎支持所有这些隔离级别: · 未提交读(隔离事务的最低级别,只能保证不读取物理上损坏的数据) · 已提交读(数据库引擎的默认级...

转:手把手教你安装MBAM 2.5 SP1

本文转载自http://bbs.learnfuture.com/topic/1588,按照教程练手,并对其中部分描述不完整及环境差异部分做补充说明。 【前言】 BitLocker驱动器加密是一项数据保护功能,它与操作系统集成,用于解决来自丢失、被盗或销毁不当的计算机的数据被盗或泄露的问题。针对该技术,微软专门推出了MBAM(Microsoft BitLoc...

SaaS模式应用之多租户系统开发(单数据库多Schema设计)

SaaS是Software-as-a-Service(软件即服务)的简称,这边具体的解释不介绍。 多租户的系统可以应用这种模式的思想,将思想融入到系统的设计之中。 一、多租户的系统,目前在数据库存储上,一般有三种解决方案: 1.独立数据库 2.共享数据库,隔离数据架构 3.共享数据库,共享数据架构 这里我就系统的实际需求情况,选择了第二种解决方案,下面简单...

sqlserver事务日志增长过快

问题背景:客户反馈sqlserver数据库日志增长迅速,两分钟增长好几个g,目前数据库已改为简单模式 sqlserver 日志文件不停增长的原因日志不停增长的原因 1.数据库是完整模式,但是并没有定期的进行日志备份。日志备份可以截断事务,可以使得空间重用。解决这个问题,只需做好日志定时备份的计划作业就行 2.有事务长时间没有提交由于开发人员的粗心大意,没有...

将SqlServer的数据导出到Excel/csv中的各种方法 .

以下都只是介绍操作的原理,具体要求要在应用中具体分析改变。 如果大家有其他好的方法,请相互告知,共同学习。 1.       此方法常用在form或者Console Application中,使用时须用要添加Reference,具体做法:           右键点击项目添加“Add Reference”,在com组件下,选择“Microsoft Exc...