概述SqlServer中的
数据类型UniqueIdentifier到底是什么东东? 该类型一般用来做为主键使用,可用SQL语法的newid()来生成一个唯一的值。 我想请问的是,这个值是一个长整型的数据值呢,还是个其它的什么值?我在程序中该如何去控制他? 欢迎多多交流。 摘自帮助: uniqueidentifier 全局唯一标识符 (GUID)。 注释 uniqueidentifier 数 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 使用服务器上的网卡生成。由应用程序 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全部内容,希望文章能够帮你解决SqlServer中的数据类型UniqueIdentifier所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
评论列表(0条)