SQLServer中NEWID()函数用于生成一个唯一的标识符的方法实践
在SQL Server中,NEWID()
函数用于生成一个唯一的标识符(GUID,即全局唯一标识符)。GUID是一个128位的数字,由算法生成,以保证在全球范围内的唯一性。它通常用于数据库表中作为主键,以确保每条记录都能被唯一地识别。
使用NEWID()
函数时,它会立即生成一个新的GUID值,这个值在数据库中是唯一的(尽管理论上存在极小的碰撞可能性,但在实际应用中几乎不可能发生)。
1、本文内容
- 语法
- 返回类型
- 注解
- 示例
适用于:
- SQL Server
- Azure SQL 数据库
- Azure SQL 托管实例
- Azure Synapse Analytics
- Microsoft Fabric 中的 SQL 分析终结点
- Microsoft Fabric 中的仓库
创建 uniqueidentifier 类型的唯一值。
参考官方文档地址
https://learn.microsoft.com/zh-cn/sql/t-sql/functions/newid-transact-sql?view=sql-server-ver16
2、语法
NEWID()
3、返回类型
uniqueidentifier
4、注解
NEWID() 遵从 RFC4122。
5、示例
5.1、CREATE TABLE 语句中使用 NEWID
假设你有一个名为Employees
的表,其中包含EmployeeID
(GUID类型的主键)和EmployeeName
两个字段。你可以使用NEWID()
函数在插入新记录时自动生成EmployeeID
的值。
CREATE TABLE Employees ( EmployeeID UNIQUEIDENTIFIER CONSTRAINT PK_Employees_EmployeeID PRIMARY KEY CONSTRAINT df_Employees_newid DEFAULT NEWID(), EmployeeName NVARCHAR(100) ); -- 插入新记录时,EmployeeID将自动由NEWID()生成 INSERT INTO Employees (EmployeeName) VALUES ('John Doe'),(N'主键约束'),(N'默认值约束'); -- 查看插入的记录 SELECT * FROM Employees; EmployeeID EmployeeName ------------------------------------ ------------------------------------------------- A622FFE4-10B2-46BC-BAC6-4505495845D2 John Doe 75D6A200-0A8A-4247-B446-E7CB79A59EA0 默认值约束 4BAFD083-E206-46FC-A8A8-F5FE3150871B 主键约束 (3 行受影响)
在这个例子中,EmployeeID
列被设置为UNIQUEIDENTIFIER
类型,并且有一个默认值NEWID()
。这意味着每当向Employees
表中插入新记录时,如果未明确指定EmployeeID
的值,SQL Server将自动使用NEWID()
函数生成一个新的GUID值作为该记录的主键值。
5.2、对变量使用 NEWID 函数
以下示例使用 NEWID() 对声明为 uniqueidentifier 数据类型的变量赋值。 在测试 uniqueidentifier 数据类型变量的值之前,先打印该值。
-- Creating a local variable with DECLARE/SET syntax. DECLARE @myid uniqueidentifier SET @myid = NEWID() PRINT 'Value of @myid is: '+ CONVERT(varchar(255), @myid)
下面是结果集。
Value of @mynewid is: ED3C2013-ABA3-4C61-91AA-D362DE37C853
5.3、使用 uniqueidentifier 和变量赋值
以下示例将名为 @mynewid 的局部变量声明为 uniqueidentifier 数据类型的变量。 然后使用 SET 语句为该变量赋值。
DECLARE @mynewid uniqueidentifier ; SET @mynewid = 'A9CBD0DB-F4A6-4E55-92C6-4C5116A1DD9E'; SELECT @mynewid AS sysguid; GO sysguid ------------------------------------ A9CBD0DB-F4A6-4E55-92C6-4C5116A1DD9E (1 行受影响)
5.4、使用 NEWID() 函数查询随机数据
以下示例使用 NEWID() 函数从 Production.Product 表中查询随机记录。 若要随机查询更多记录,请增加 TOP 值。
SELECT TOP 1 ProductID, Name, ProductNumber FROM Production.Product ORDER BY NEWID() GO ProductID Name ProductNumber ----------- -------------------------------------------------- ------------------------- 824 ML Mountain Rear Wheel RW-M762 (1 行受影响) -- 第二次执行,返回结果和前一次可能不同,则是ORDER BY NEWID()随机排序查询的作用 ProductID Name ProductNumber ----------- -------------------------------------------------- ------------------------- 842 Touring-Panniers, Large PA-T100 (1 行受影响)
6、 注意
- 虽然GUID在全局范围内是唯一的,但它们并不是顺序生成的。这意呀着,如果你在一个有大量插入操作的数据库中使用GUID作为主键,并且这些操作依赖于主键的顺序(例如,在索引页中),那么性能可能会受到影响。
- 在某些情况下,你可能希望使用顺序的标识符(如自增的整数)作为主键,以优化性能。然而,如果你需要确保跨多个数据库或系统的唯一性,或者出于其他原因需要使用全局唯一的标识符,那么GUID是一个很好的选择。
到此这篇关于SQLServer中NEWID()函数用于生成一个唯一的标识符的方法实践的文章就介绍到这了,更多相关SQL NEWID()函数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
SQL SERVER2012中新增函数之字符串函数CONCAT详解
SQL Server 2012有一个新函数,就是CONCAT函数,连接字符串非它莫属。比如在它出现之前,连接字符串是使用"+"来连接,如遇上NULL,还得设置参数与配置,不然连接出来的结果将会是一个NULL。本文就介绍了关于SQL SERVER 2012中CONCAT函数的相关资料,需要的朋友可以参考。2017-03-03SQL Server误区30日谈 第1天 正在运行的事务在服务器故障转移后继续执行
每次故障转移都伴随着某种形式的恢复。但是如果当正在执行的事务没有Commit时,由于服务器或实例崩溃导致连接断开,SQL Server可没有办法在故障转移后的服务器重新建立事务的上下文并继续执行事务-无论你使用的故障转移方式是集群,镜像,日志传送或是SAN复制2013-01-01SQL Server的FileStream和FileTable深入剖析
互联网时代数据是爆炸式增长,我们常常需要把结构化数据和非结构化数据存储在一起。本文将介绍几种解决方案2012-11-11SQL Server 2022 Enterprise安装部署的实现步骤
SQL Server 2022是一款功能强大的关系型数据库管理系统,它提供了稳定可靠的数据存储和管理功能,本文主要介绍了SQL Server 2022 Enterprise部署的实现步骤,具有一定的参考价值,感兴趣的可以了解一下2024-04-04
最新评论