uniqueidentifier类型_unique唯一索引

uniqueidentifier类型_unique唯一索引INSERT语句:CREATETABLEMyUniqueTable(UniqueColumnUNIQUEIDENTIFIERDEFAULTNEWID(),CharactersVARCHAR(10))GOINSERTINTOMyUniqueTable(Characters)VALUES…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

 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  

  全局唯一标识符   (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   属性。  

转载于:https://www.cnblogs.com/liufei88866/archive/2007/12/05/983675.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/196181.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • springsession使用_常见的使用null场景

    springsession使用_常见的使用null场景目录一、同域名下相同项目(集群环境)实现Session共享1.思路2.架构图3.实现步骤一、同域名下相同项目(集群环境)实现Session共享在同一个域名下,比如:www.p2p.com同一个项目,部署了多台tomcat,这就是典型的集群。我们上一篇文章的入门案例就属于这种应用场景,只不过在实际开发的过程中,我们如果存在了tomcat集群,那么肯定会使用nginx进行负载均衡,那么这种情况下我们该如何处理。1.思路我们将上一个阶段的p2p项目实现集群部署下的Ses

  • pycharm专业版学生激活_pycharm激活教程

    pycharm专业版学生激活_pycharm激活教程Pycharm专业版_学生用户激活Pychram学生账户激活FreeEducationalLicenses填写申请人信息无法接受邮箱申请Pychram学生账户激活FreeEducationalLicensesFreeEducationalLicenses网址点击Applynow填写申请人信息填写个人信息,邮箱必须使用校园邮箱号,每个大学都有对应的邮箱帐号,可以去校园网自行申请点击申请免费产品无法接受邮箱申请如果出现无法接受电子邮件地址,点击蓝色的“官方文件”进行申请确认

  • RAPIDxml的使用「建议收藏」

    RAPIDxml的使用「建议收藏」对RAPIDxml使用的介绍和举例。

  • 实体-联系图(ER图)_实体关系图

    实体-联系图(ER图)_实体关系图我们通常用实体、联系和属性这三个概念来理解现实问题,因此ER模型比较接近人的思维方式。此外,ER模型用简单的图形符号表达系统分析员对问题域的理解,不熟悉计算机技术的用户也能理解它,因此,ER模型可以作为用户与分析员之间有效的交流工具。一、ER模型ER模型中包含3种相互关联的信息:数据对象、数据对象的属性及数据对象彼此之间相互连接的关系。1.数据对象数据对象是对软件必须理解的复合信息…

  • css 滤镜之AlphaImageLoader「建议收藏」

    css 滤镜之AlphaImageLoader「建议收藏」CreateTime–2017年12月25日17:05:37Author:Marydonie滤镜特效之AlphaImageLoader作用:用于设置背景图片特效样式使用条件:IE8及以下

  • 怎么测试网站的稳定性_稳定性长期试验需进行多少个月试验

    怎么测试网站的稳定性_稳定性长期试验需进行多少个月试验今天面试遇到一个问题,如何进行网站的稳定性测试?因为之前从事的是电信行业,其稳定性测试是发送确定的traffic,运行72小时,观测系统的资源使用情况,traffic处理是否正常,有无内存泄漏,有无进程崩溃,其他资源使用是否正常等等。所以也给了一个类似的稳定性测试思路:按照系统设计容量的性能指标,模拟最大并发访问需求,运行72小时,看系统响应时间,监控资源利用的方法。回来查询发现,网易对这个问题也…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号