SQLServer中NEWID()函數(shù)用于生成一個(gè)唯一的標(biāo)識(shí)符的方法實(shí)踐
在SQL Server中,NEWID()
函數(shù)用于生成一個(gè)唯一的標(biāo)識(shí)符(GUID,即全局唯一標(biāo)識(shí)符)。GUID是一個(gè)128位的數(shù)字,由算法生成,以保證在全球范圍內(nèi)的唯一性。它通常用于數(shù)據(jù)庫(kù)表中作為主鍵,以確保每條記錄都能被唯一地識(shí)別。
使用NEWID()
函數(shù)時(shí),它會(huì)立即生成一個(gè)新的GUID值,這個(gè)值在數(shù)據(jù)庫(kù)中是唯一的(盡管理論上存在極小的碰撞可能性,但在實(shí)際應(yīng)用中幾乎不可能發(fā)生)。
1、本文內(nèi)容
- 語(yǔ)法
- 返回類(lèi)型
- 注解
- 示例
適用于:
- SQL Server
- Azure SQL 數(shù)據(jù)庫(kù)
- Azure SQL 托管實(shí)例
- Azure Synapse Analytics
- Microsoft Fabric 中的 SQL 分析終結(jié)點(diǎn)
- Microsoft Fabric 中的倉(cāng)庫(kù)
創(chuàng)建 uniqueidentifier 類(lèi)型的唯一值。
參考官方文檔地址
https://learn.microsoft.com/zh-cn/sql/t-sql/functions/newid-transact-sql?view=sql-server-ver16
2、語(yǔ)法
NEWID()
3、返回類(lèi)型
uniqueidentifier
4、注解
NEWID() 遵從 RFC4122。
5、示例
5.1、CREATE TABLE 語(yǔ)句中使用 NEWID
假設(shè)你有一個(gè)名為Employees
的表,其中包含EmployeeID
(GUID類(lèi)型的主鍵)和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
類(lèi)型,并且有一個(gè)默認(rèn)值NEWID()
。這意味著每當(dāng)向Employees
表中插入新記錄時(shí),如果未明確指定EmployeeID
的值,SQL Server將自動(dòng)使用NEWID()
函數(shù)生成一個(gè)新的GUID值作為該記錄的主鍵值。
5.2、對(duì)變量使用 NEWID 函數(shù)
以下示例使用 NEWID() 對(duì)聲明為 uniqueidentifier 數(shù)據(jù)類(lèi)型的變量賦值。 在測(cè)試 uniqueidentifier 數(shù)據(jù)類(lèi)型變量的值之前,先打印該值。
-- 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ù)類(lèi)型的變量。 然后使用 SET 語(yǔ)句為該變量賦值。
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ù)查詢(xún)隨機(jī)數(shù)據(jù)
以下示例使用 NEWID() 函數(shù)從 Production.Product 表中查詢(xún)隨機(jī)記錄。 若要隨機(jī)查詢(xún)更多記錄,請(qǐng)?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ī)排序查詢(xún)的作用 ProductID Name ProductNumber ----------- -------------------------------------------------- ------------------------- 842 Touring-Panniers, Large PA-T100 (1 行受影響)
6、 注意
- 雖然GUID在全局范圍內(nèi)是唯一的,但它們并不是順序生成的。這意呀著,如果你在一個(gè)有大量插入操作的數(shù)據(jù)庫(kù)中使用GUID作為主鍵,并且這些操作依賴(lài)于主鍵的順序(例如,在索引頁(yè)中),那么性能可能會(huì)受到影響。
- 在某些情況下,你可能希望使用順序的標(biāo)識(shí)符(如自增的整數(shù))作為主鍵,以?xún)?yōu)化性能。然而,如果你需要確??缍鄠€(gè)數(shù)據(jù)庫(kù)或系統(tǒng)的唯一性,或者出于其他原因需要使用全局唯一的標(biāo)識(shí)符,那么GUID是一個(gè)很好的選擇。
到此這篇關(guān)于SQLServer中NEWID()函數(shù)用于生成一個(gè)唯一的標(biāo)識(shí)符的方法實(shí)踐的文章就介紹到這了,更多相關(guān)SQL NEWID()函數(shù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SQL Server 數(shù)據(jù)庫(kù)管理常用的SQL和T-SQL語(yǔ)句
SQL Server 數(shù)據(jù)庫(kù)管理常用的SQL和T-SQL語(yǔ)句...2006-08-08SQL查詢(xún)某列指定長(zhǎng)度的字符串多余的用省略號(hào)來(lái)表示
有時(shí)候?yàn)榱嗣烙^,只需要顯示前面幾個(gè)字符串,剩下的可以用省略號(hào)來(lái)表示,下面有個(gè)不錯(cuò)的示例,感興趣的朋友可以參考下2013-11-11如何在SQLSERVER中快速有條件刪除海量數(shù)據(jù)
如何在SQLSERVER中快速有條件刪除海量數(shù)據(jù)...2006-09-09SQL Server解決游標(biāo)性能問(wèn)題的替代方案
游標(biāo)是一種能從包含多個(gè)元組的集合中每次讀取一個(gè)元組的機(jī)制,游標(biāo)總是和一段SELECT語(yǔ)句關(guān)聯(lián),SELECT語(yǔ)句查詢(xún)出的結(jié)果集就作為集合,游標(biāo)能每次從該集合中讀取出一個(gè)元組進(jìn)行不同操作,但在某些情況下,它們可能會(huì)導(dǎo)致性能問(wèn)題,本介紹了SQL Server解決游標(biāo)性能問(wèn)題的替代方案2024-12-12使用用SQL語(yǔ)句從電腦導(dǎo)入圖片到數(shù)據(jù)庫(kù)的方法
這篇文章主要介紹了用SQL語(yǔ)句從電腦導(dǎo)入圖片到數(shù)據(jù)庫(kù)的方法,文中給大家提到了從MySQL數(shù)據(jù)庫(kù)讀取圖片和向數(shù)據(jù)庫(kù)插入圖片的代碼,需要的朋友可以參考下2019-09-09圖解SSIS批量導(dǎo)入Excel文件的實(shí)現(xiàn)方法
本篇文章是對(duì)SSIS批量導(dǎo)入Excel文件的實(shí)現(xiàn)方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06