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

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

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

在SQL Server中,NEWID() 函數(shù)用于生成一個唯一的標識符(GUID,即全局唯一標識符)。GUID是一個128位的數(shù)字,由算法生成,以保證在全球范圍內的唯一性。它通常用于數(shù)據(jù)庫表中作為主鍵,以確保每條記錄都能被唯一地識別。

使用NEWID()函數(shù)時,它會立即生成一個新的GUID值,這個值在數(shù)據(jù)庫中是唯一的(盡管理論上存在極小的碰撞可能性,但在實際應用中幾乎不可能發(fā)生)。

1、本文內容

  • 語法
  • 返回類型
  • 注解
  • 示例

適用于:

  • SQL Server
  • Azure SQL 數(shù)據(jù)庫
  • Azure SQL 托管實例
  • Azure Synapse Analytics
  • Microsoft Fabric 中的 SQL 分析終結點
  • 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

假設你有一個名為Employees的表,其中包含EmployeeID(GUID類型的主鍵)和EmployeeName兩個字段。你可以使用NEWID()函數(shù)在插入新記錄時自動生成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()函數(shù)生成一個新的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)

下面是結果集。

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ù)查詢隨機數(shù)據(jù)

以下示例使用 NEWID() 函數(shù)從 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 行受影響)

-- 第二次執(zhí)行,返回結果和前一次可能不同,則是ORDER BY NEWID()隨機排序查詢的作用
ProductID   Name                                               ProductNumber
----------- -------------------------------------------------- -------------------------
842         Touring-Panniers, Large                            PA-T100

(1 行受影響)

6、 注意

  • 雖然GUID在全局范圍內是唯一的,但它們并不是順序生成的。這意呀著,如果你在一個有大量插入操作的數(shù)據(jù)庫中使用GUID作為主鍵,并且這些操作依賴于主鍵的順序(例如,在索引頁中),那么性能可能會受到影響。
  • 在某些情況下,你可能希望使用順序的標識符(如自增的整數(shù))作為主鍵,以優(yōu)化性能。然而,如果你需要確??缍鄠€數(shù)據(jù)庫或系統(tǒng)的唯一性,或者出于其他原因需要使用全局唯一的標識符,那么GUID是一個很好的選擇。

 到此這篇關于SQLServer中NEWID()函數(shù)用于生成一個唯一的標識符的方法實踐的文章就介紹到這了,更多相關SQL NEWID()函數(shù)內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

最新評論