SqlServer中的数据类型UniqueIdentifier究竟是什么东东? |
该类型一般用来做为主键使用,可用SQL语法的newid()来生成一个唯一的值。 我想请问的是,这个值是一个长整型的数据值呢,还是个其他的什么值?我在程序中该怎样去控制他? 欢迎多多交流。 |
摘自帮助:
uniqueidentifier 凝视 使用 NEWID 函数。 将字符串常量转换为例如以下形式(xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx,当中每一个 x 是 0-9 或 a-f 范围内的一个十六进制的数字)。比如,6F9619FF-8B86-D011-B42D-00C04FC964FF 即为有效的 uniqueidentifier 值。 使用 uniqueidentifier 数据 uniqueidentifier 列的 GUID 值通常由下面方式获得: 在 Transact-SQL 语句、批处理或脚本中调用 NEWID 函数。 在应用程序代码中,调用返回 GUID 值的应用程序 API 函数或方法。 一般不将 uniqueidentifier 定义为常量,由于非常难保证实际创建的 uniqueidentifier 具有唯一性。指定 uniqueidentifier 常量的方法有两种: 字符串格式 二进制格式 uniqueidentifier 数据类型不象IDENTITY 属性那样为新插入的行自己主动生成新的ID。为了得到新的 uniqueidentifier 值,表必须具有一个指定 NEWID 函数的 DEFAULT 子句,或使用 NEWID 函数的 INSERT 语句: CREATE TABLE MyUniqueTable 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 键实现的索引相对慢一些。 ^_^ |
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
时间: 2024-07-30 10:18:08
SqlServer中的数据类型UniqueIdentifier的相关文章
SQLServer中间接实现函数索引或者Hash索引
本文出处:http://www.cnblogs.com/wy123/p/6617700.html SQLServer中没有函数索引,在某些场景下查询的时候要根据字段的某一部分做查询或者经过某种计算之后做查询,如果使用函数或者其他方式作用在字段上之后,就会限制到索引的使用,不过我们可以间接地实现类似于函数索引的功能.另外一个就是如果查询字段较大或者字段较多的时候,所建立的索引就显得有点笨重,效率也不高,就需要考虑使用一个较小的"替代性"字段做等价替换,类似于Hash索引,本文粗浅地介绍两
SQL Server 2005 中的数据类型总结
注:转自土豆网 SQL Server 2005 中的数据类型归纳为下列类别: 精确数字 bigint decimal int numeric smallint money tinyint smallmoney bit 近似数字 float real 日期和时间 datetime smalldatetime 字符串 char text varchar Unicode字符串 nchar ntext nvarchar 二进制字符串 binary image varbinary 其他数据类型 curso
XML 在SQLServer中的使用
SQL Server对于XML支持的核心在于XML数据的格式,这种数据类型可以将XML的数据存储于数据库的对象中,比如variables, columns, and parameters.当你用XML数据类型配置这些对象中的一个时,你指定类型的名字就像你在SQLServer 中指定一个类型一样. XML的数据类型确保了你的XML数据被完好的构建保存,同时也符合ISO的标准.在定义一个XML数据类型之前,我们首先要知道它的几种限制,如下: 一个实例的XML列不能包含超过2GB的数据. 一个XML的
SQLServer---查询过程中的数据类型转化
SQLServer---查询过程中的数据类型转化 前两天在维护某市人才服务中心的人事档案管理系统的时候,发现了这个一个问题新的档案编号规则是日期+已有档案最大编号+1(六位,不足六位在中间补零)(((CONVERT([varchar](9),[createTime],(112))+'')+right((100000000000.)+[num],(6))))例如:20150511007841.说实话真的不清楚当时为什么会用最大编号,而不是用总记录数+1(不存在删除数据),接下来说说遇到的问题,以及
SQLServer 中存储过程
SQLServer 中存储过程返回的三种方式( 包括存储过程的创建, 在存储过程中调用, 在VS中调用的方法)存储过程有三种返回: 1. 用return返回数字型数据 2. 用返回参数返回结果,可以返回各种数据类型(通过游标来循环查询结果每一行) 3. 直接在存储过程中用select返回结果集,可以是任意的select语句,这意味着是任意的返回结果集 方法一:用return返回数字型数据 1. 创建存储过程--SQLSERVER 2005示例数据库USE Adventur
( 转)Sqlserver中tinyint, smallint, int, bigint的区别 及 10进制转换16进制的方法
一.类型比较 bigint:从-2^63(-9223372036854775808)到2^63-1(9223372036854775807)的整型数据,存储大小为 8 个字节.一个字节就是8位,那么bigint就有64位 int:从-2^31(-2,147,483,648)到2^31-1(2,147,483,647)的整型数据,存储大小为 4 个字节.int类型,最大可以存储32位的数据 smallint:从-2^15(-32,768)到2^15-1(32,767)的整数数据,存储大小为 2 个
转换SQL命令中的数据类型出现的错误
转换SQL命令中的数据类型出现的错误 转载▼ 问题陈述: 执行 SELECT * FROM XXX_ORIGINAL_20031205 where msgid=62010388000012 语句,结果SQL Server报告出错:“将数据类型 varchar 转换为 numeric 时出错.” 这是什么意思呢? Msgid这个字段的类型是:varchar(30). 环境: 数据库服务器:Microsoft SQL Server 2000以及7.0: 数据库服务器补丁:Microsoft SQL
ArcCatalog中将SQLServer中的空间数据导入到Oracle库中
ArcCatalog中将SQLServer中的空间数据导入到Oracle库中 1.在ArcCatalog中新建数据库连接->SQLServer 2.在ArcCatalog中新建数据库连接->Oracle 3.SQLServer中的空间数据导入到Oracle库中 这里有两种方法可以使用: 1)复制粘贴数据 在源数据库(SQLServer)中选择要导出的数据,右键点击copy 在目标数据库(Oracle)中右键点击paste 特别需要注意的是: 将Config.Keyword项的默认值DEFAUL
数据库中字段类型对应的C#中的数据类型
数据库中字段类型对应C#中的数据类型: 数据库 C#程序 int int32 text string bigint int64 binary System.Byte[] bit Boolean char string datetime System.DateTime decimal System.Decimal float System.Double image System.Byte[] money System.Decimal nchar String n