欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SQLServer中NEWID()函數(shù)用于生成一個(gè)唯一的標(biāo)識符的方法實(shí)踐

 更新時(shí)間:2024年08月16日 08:55:17   作者:zxrhhm  
NEWID函數(shù)用于生成一個(gè)唯一的標(biāo)識符,本文主要介紹了SQLServer中NEWID()函數(shù)用于生成一個(gè)唯一的標(biāo)識符的方法實(shí)踐,具有一定的參考價(jià)值,感興趣的可以了解一下

在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)文章

最新評論