SQLServer中NEWID()函數(shù)用于生成一個(gè)唯一的標(biāo)識符的方法實(shí)踐
在SQL Server中,NEWID()
函數(shù)用于生成一個(gè)唯一的標(biāo)識符(GUID,即全局唯一標(biāo)識符)。GUID是一個(gè)128位的數(shù)字,由算法生成,以保證在全球范圍內(nèi)的唯一性。它通常用于數(shù)據(jù)庫表中作為主鍵,以確保每條記錄都能被唯一地識別。
使用NEWID()
函數(shù)時(shí),它會立即生成一個(gè)新的GUID值,這個(gè)值在數(shù)據(jù)庫中是唯一的(盡管理論上存在極小的碰撞可能性,但在實(shí)際應(yīng)用中幾乎不可能發(fā)生)。
1、本文內(nèi)容
- 語法
- 返回類型
- 注解
- 示例
適用于:
- SQL Server
- Azure SQL 數(shù)據(jù)庫
- Azure SQL 托管實(shí)例
- Azure Synapse Analytics
- Microsoft Fabric 中的 SQL 分析終結(jié)點(diǎn)
- Microsoft Fabric 中的倉庫
創(chuàng)建 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
假設(shè)你有一個(gè)名為Employees
的表,其中包含EmployeeID
(GUID類型的主鍵)和EmployeeName
兩個(gè)字段。你可以使用NEWID()
函數(shù)在插入新記錄時(shí)自動(dòng)生成EmployeeID
的值。
CREATE TABLE Employees ( EmployeeID UNIQUEIDENTIFIER CONSTRAINT PK_Employees_EmployeeID PRIMARY KEY CONSTRAINT df_Employees_newid DEFAULT NEWID(), EmployeeName NVARCHAR(100) ); -- 插入新記錄時(shí),EmployeeID將自動(dòng)由NEWID()生成 INSERT INTO Employees (EmployeeName) VALUES ('John Doe'),(N'主鍵約束'),(N'默認(rèn)值約束'); -- 查看插入的記錄 SELECT * FROM Employees; EmployeeID EmployeeName ------------------------------------ ------------------------------------------------- A622FFE4-10B2-46BC-BAC6-4505495845D2 John Doe 75D6A200-0A8A-4247-B446-E7CB79A59EA0 默認(rèn)值約束 4BAFD083-E206-46FC-A8A8-F5FE3150871B 主鍵約束 (3 行受影響)
在這個(gè)例子中,EmployeeID
列被設(shè)置為UNIQUEIDENTIFIER
類型,并且有一個(gè)默認(rèn)值NEWID()
。這意味著每當(dāng)向Employees
表中插入新記錄時(shí),如果未明確指定EmployeeID
的值,SQL Server將自動(dòng)使用NEWID()
函數(shù)生成一個(gè)新的GUID值作為該記錄的主鍵值。
5.2、對變量使用 NEWID 函數(shù)
以下示例使用 NEWID() 對聲明為 uniqueidentifier 數(shù)據(jù)類型的變量賦值。 在測試 uniqueidentifier 數(shù)據(jù)類型變量的值之前,先打印該值。
-- Creating a local variable with DECLARE/SET syntax. DECLARE @myid uniqueidentifier SET @myid = NEWID() PRINT 'Value of @myid is: '+ CONVERT(varchar(255), @myid)
下面是結(jié)果集。
Value of @mynewid is: ED3C2013-ABA3-4C61-91AA-D362DE37C853
5.3、使用 uniqueidentifier 和變量賦值
以下示例將名為 @mynewid 的局部變量聲明為 uniqueidentifier 數(shù)據(jù)類型的變量。 然后使用 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() 函數(shù)查詢隨機(jī)數(shù)據(jù)
以下示例使用 NEWID() 函數(shù)從 Production.Product 表中查詢隨機(jī)記錄。 若要隨機(jī)查詢更多記錄,請?jiān)黾?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 行受影響) -- 第二次執(zhí)行,返回結(jié)果和前一次可能不同,則是ORDER BY NEWID()隨機(jī)排序查詢的作用 ProductID Name ProductNumber ----------- -------------------------------------------------- ------------------------- 842 Touring-Panniers, Large PA-T100 (1 行受影響)
6、 注意
- 雖然GUID在全局范圍內(nèi)是唯一的,但它們并不是順序生成的。這意呀著,如果你在一個(gè)有大量插入操作的數(shù)據(jù)庫中使用GUID作為主鍵,并且這些操作依賴于主鍵的順序(例如,在索引頁中),那么性能可能會受到影響。
- 在某些情況下,你可能希望使用順序的標(biāo)識符(如自增的整數(shù))作為主鍵,以優(yōu)化性能。然而,如果你需要確??缍鄠€(gè)數(shù)據(jù)庫或系統(tǒng)的唯一性,或者出于其他原因需要使用全局唯一的標(biāo)識符,那么GUID是一個(gè)很好的選擇。
到此這篇關(guān)于SQLServer中NEWID()函數(shù)用于生成一個(gè)唯一的標(biāo)識符的方法實(shí)踐的文章就介紹到這了,更多相關(guān)SQL NEWID()函數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SQL Server 數(shù)據(jù)庫管理常用的SQL和T-SQL語句
SQL Server 數(shù)據(jù)庫管理常用的SQL和T-SQL語句...2006-08-08如何在SQLSERVER中快速有條件刪除海量數(shù)據(jù)
如何在SQLSERVER中快速有條件刪除海量數(shù)據(jù)...2006-09-09使用用SQL語句從電腦導(dǎo)入圖片到數(shù)據(jù)庫的方法
這篇文章主要介紹了用SQL語句從電腦導(dǎo)入圖片到數(shù)據(jù)庫的方法,文中給大家提到了從MySQL數(shù)據(jù)庫讀取圖片和向數(shù)據(jù)庫插入圖片的代碼,需要的朋友可以參考下2019-09-09圖解SSIS批量導(dǎo)入Excel文件的實(shí)現(xiàn)方法
本篇文章是對SSIS批量導(dǎo)入Excel文件的實(shí)現(xiàn)方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06