日韩欧美人妻无码精品白浆,www.大香蕉久久网,狠狠的日狠狠的操,日本好好热在线观看

LOGO OA教程 ERP教程 模切知識(shí)交流 PMS教程 CRM教程 開(kāi)發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

SQLServer 唯一約束與唯一索引的區(qū)別

admin
2025年1月9日 22:1 本文熱度 1074

唯一約束和唯一索引在表設(shè)計(jì)中是最常見(jiàn)的,都有唯一屬性,用于約束表字段的唯一性。但是,這兩者到底有什么區(qū)別呢?


接下來(lái)我們測(cè)試看看,創(chuàng)建兩張表分別用于測(cè)試唯一約束和唯一索引。

USE [DemoDB]GOCREATE TABLE [dbo].[TableUniqueKey](  id int not null,  name varchar(20) null)GOCREATE TABLE [dbo].[TableUniqueIndex](  id int not null,  name varchar(20) null)GOINSERT INTO [dbo].[TableUniqueKey]SELECT 1,'KK' UNION ALLSELECT 2,NULL UNION ALLSELECT 3,NULL GOINSERT INTO [dbo].[TableUniqueIndex]SELECT 1,'KK' UNION ALLSELECT 2,NULL UNION ALLSELECT 3,NULL GO

現(xiàn)在分別創(chuàng)建唯一鍵約束和創(chuàng)建唯一索引,發(fā)現(xiàn)錯(cuò)誤!

--  創(chuàng)建唯一鍵約束ALTER TABLE [dbo].[TableUniqueKey] ADD CONSTRAINT [IX_TableUniqueKey_name] UNIQUE ([name] ASC)--默認(rèn)非聚集索引GOALTER TABLE [dbo].[TableUniqueKey] ADD CONSTRAINT [IX_TableUniqueKey_name] UNIQUE NONCLUSTERED([name] ASC)GO--  創(chuàng)建唯一索引CREATE UNIQUE NONCLUSTERED INDEX [IX_UniqueIndex_name] ON [dbo].[TableUniqueIndex]([name] ASC)GO

Msg 1505, Level 16, State 1, Line 1
The CREATE UNIQUE INDEX statement terminated because a duplicate key was found for the object name 'dbo.TableUniqueKey' and the index name 'IX_TableUniqueKey_name'. The duplicate key value is (<NULL>).
Msg 1750, Level 16, State 0, Line 1 Could not create constraint. See previous errors.

The statement has been terminated.

Msg 1505, Level 16, State 1, Line 1
The CREATE UNIQUE INDEX statement terminated because a duplicate key was found for the object name 'dbo.TableUniqueIndex' and the index name 'IX_UniqueIndex_name'. The duplicate key value is (<NULL>).

The statement has been terminated.


可以看到,都提示有重復(fù)值,重復(fù)值均為 NULL 值?,F(xiàn)在刪除重復(fù)值,再創(chuàng)建唯一約束。

DELETE FROM [dbo].[TableUniqueKey] WHERE ID = 3DELETE FROM [dbo].[TableUniqueIndex] WHERE ID = 3--  創(chuàng)建唯一鍵約束ALTER TABLE [dbo].[TableUniqueKey] ADD CONSTRAINT [IX_TableUniqueKey_name] UNIQUE NONCLUSTERED([name] ASC)



創(chuàng)建唯一鍵約束,會(huì)同時(shí)創(chuàng)建同名的唯一非聚集索引, 以及創(chuàng)建同名統(tǒng)計(jì)信息;而唯一鍵約束是靠唯一索引來(lái)約束。


若是對(duì)唯一鍵生成的索引直接刪除,則報(bào)錯(cuò)!

DROP INDEX [IX_TableUniqueKey_name] ON [dbo].[TableUniqueKey]

Msg 3723, Level 16, State 5, Line 1
An explicit DROP INDEX is not allowed on index 'dbo.TableUniqueKey.IX_TableUniqueKey_name'. It is being used for UNIQUE KEY constraint enforcement.


正確的刪除方法,是刪除表約束。

ALTER TABLE [dbo].[TableUniqueKey] DROP CONSTRAINT [IX_TableUniqueKey_name]


繼續(xù)測(cè)試,現(xiàn)在對(duì)另一張表創(chuàng)建唯一索引。


CREATE UNIQUE NONCLUSTERED INDEX [IX_UniqueIndex_name] ON [dbo].[TableUniqueIndex]([name] ASC)


創(chuàng)建唯一索引, 同時(shí)創(chuàng)建同名統(tǒng)計(jì)信息。


對(duì)索引刪除后,我們?cè)僦亟ǎ瑢?duì)比再看看。

DROP INDEX [IX_UniqueIndex_name] ON [dbo].[TableUniqueIndex]GOALTER TABLE [dbo].[TableUniqueKey] ADD CONSTRAINT [IX_TableUniqueKey_name] UNIQUE NONCLUSTERED([name] ASC)GOCREATE UNIQUE NONCLUSTERED INDEX [IX_UniqueIndex_name] ON [dbo].[TableUniqueIndex]([name] ASC)GOSELECT object_name(object_id),name,index_id,type_desc,is_unique,is_unique_constraintFROM sys.indexes WHERE object_name(object_id) IN ('TableUniqueKey','TableUniqueIndex')


唯一鍵約束 [TableUniqueKey] 不是 check 約束,是屬于一種為 UNIQUE_CONSTRAINT 的約束。而他們的索引都有唯一性約束。


此外,還可以通過(guò)以下檢查他們的區(qū)別:

EXEC sp_helpconstraint 'TableUniqueKey' EXEC sp_helpconstraint 'TableUniqueIndex' 
EXEC sp_helpindex 'TableUniqueKey' EXEC sp_helpindex 'TableUniqueIndex' 
--  EXEC sp_help 'TableUniqueKey' --  EXEC sp_help 'TableUniqueIndex'


對(duì)比索引描述中,唯一鍵 比 唯一 索引多了 unique key 。

--唯一鍵不出錯(cuò)EXEC sp_help [IX_TableUniqueKey_name]EXEC sp_helpindex [IX_TableUniqueKey_name]EXEC sp_helpconstraint [IX_TableUniqueKey_name]--唯一索引出錯(cuò)EXEC sp_help [IX_UniqueIndex_name]EXEC sp_helpindex [IX_UniqueIndex_name]EXEC sp_helpconstraint [IX_UniqueIndex_name]

上面可以看出,唯一不同的是: 唯一鍵 比 唯一索引 多了一種叫做 "unique key" 的約束。


現(xiàn)在禁用索引,再插入重復(fù)數(shù)據(jù)。

--禁用索引/約束(均可被禁用)ALTER INDEX [IX_TableUniqueKey_name] ON [dbo].[TableUniqueKey] DISABLEALTER INDEX [IX_UniqueIndex_name] ON [dbo].[TableUniqueIndex] DISABLE--插入重復(fù)值,正常INSERT INTO [dbo].[TableUniqueKey] SELECT 3,NULL INSERT INTO [dbo].[TableUniqueIndex]SELECT 3,NULL

數(shù)據(jù)都能正常插入,約束或索引被禁用了。對(duì)于唯一鍵約束,也是禁用索引嗎?函數(shù) ObjectProperty() 的參數(shù) CnstIsDisabled 可以確認(rèn)約束是否被禁用。

SELECT ObjectProperty(object_id('IX_TableUniqueKey_name'),'CnstIsDisabled')

結(jié)果為 0 ,即約束沒(méi)有被禁用,也就是說(shuō)禁用的是索引,唯一鍵約束中,唯一性是依賴于其默認(rèn)創(chuàng)建的唯一索引來(lái)約束的!


現(xiàn)在重建索引:

--刪除重復(fù)DELETE FROM [dbo].[TableUniqueKey] WHERE ID = 3DELETE FROM [dbo].[TableUniqueIndex] WHERE ID = 3/*對(duì)索引的更改*/--重建索引ALTER INDEX [IX_TableUniqueKey_name] ON [dbo].[TableUniqueKey] REBUILDALTER INDEX [IX_UniqueIndex_name] ON [dbo].[TableUniqueIndex] REBUILD--更改部分索引參數(shù)ALTER INDEX [IX_TableUniqueKey_name] ON [dbo].[TableUniqueKey] SET ( ALLOW_ROW_LOCKS = ON )ALTER INDEX [IX_UniqueIndex_name] ON [dbo].[TableUniqueIndex] SET ( ALLOW_ROW_LOCKS = ON )

兩種索引其實(shí)還是可以更改一下參數(shù)的。使用窗口打開(kāi)查看,唯一鍵約束的索引有些是不能更改的。


唯一鍵約束的索引不能像正常的索引使用太多的索引參數(shù),因?yàn)槲ㄒ绘I約束與其索引同在。而單獨(dú)創(chuàng)建的唯一索引可以設(shè)置更多的參數(shù),如 PAD_INDEX, FILLFACTOR, IGNORE_DUP_KEY, DROP_EXISTING, STATISTICS_NORECOMPUTE, and SORT_IN_TEMPDB 。


總的來(lái)說(shuō),唯一鍵鍵約束和唯一索引功能是一樣的:"唯一性" + "索引"


唯一鍵鍵約束:只是作為一種獨(dú)特的約束(如主鍵約束,唯一鍵約束,check約束,外鍵約束 的一種),以約束的形式管理.但是同時(shí)又自動(dòng)創(chuàng)建了唯一非聚集索引,也就有了索引的性能和部分功能.實(shí)際上唯一鍵約束是用唯一索引來(lái)約束的。


唯一索引:就是一種索引,它對(duì)某字段進(jìn)行唯一性檢查,同時(shí)可以設(shè)置各種參數(shù),非常靈活。


那么我們?cè)趧?chuàng)建列的唯一性時(shí),到底使用哪一種較好呢?

唯一鍵約束在表中是必定存在的約束的,唯一鍵約束的索引存在于一個(gè)分區(qū)中,并且不會(huì)像索引那樣可以更改。因?yàn)樗饕梢噪S時(shí)改動(dòng)(當(dāng)然也不會(huì)經(jīng)常改動(dòng)),個(gè)人建議索引還是用唯一索引更靈活。管理約束還得管理索引,而管理索引,一個(gè)就好了。但是對(duì)于一些高可用性,也要注意索引是否在其他地方也存在。


閱讀原文:原文鏈接


該文章在 2025/1/10 11:06:27 編輯過(guò)
關(guān)鍵字查詢
相關(guān)文章
正在查詢...
點(diǎn)晴ERP是一款針對(duì)中小制造業(yè)的專(zhuān)業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國(guó)內(nèi)大量中小企業(yè)的青睞。
點(diǎn)晴PMS碼頭管理系統(tǒng)主要針對(duì)港口碼頭集裝箱與散貨日常運(yùn)作、調(diào)度、堆場(chǎng)、車(chē)隊(duì)、財(cái)務(wù)費(fèi)用、相關(guān)報(bào)表等業(yè)務(wù)管理,結(jié)合碼頭的業(yè)務(wù)特點(diǎn),圍繞調(diào)度、堆場(chǎng)作業(yè)而開(kāi)發(fā)的。集技術(shù)的先進(jìn)性、管理的有效性于一體,是物流碼頭及其他港口類(lèi)企業(yè)的高效ERP管理信息系統(tǒng)。
點(diǎn)晴WMS倉(cāng)儲(chǔ)管理系統(tǒng)提供了貨物產(chǎn)品管理,銷(xiāo)售管理,采購(gòu)管理,倉(cāng)儲(chǔ)管理,倉(cāng)庫(kù)管理,保質(zhì)期管理,貨位管理,庫(kù)位管理,生產(chǎn)管理,WMS管理系統(tǒng),標(biāo)簽打印,條形碼,二維碼管理,批號(hào)管理軟件。
點(diǎn)晴免費(fèi)OA是一款軟件和通用服務(wù)都免費(fèi),不限功能、不限時(shí)間、不限用戶的免費(fèi)OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved

99热国产三级| 亚洲激情在线视频| 直接看的AV免费的不卡| 日韩欧美~中文字幕| 国产日韩精品自拍99| 欧美日韩成人在线精品在线观看| 久久久国产黄色电影| 国产视频日,日韩欧美| 国产青草一区| 人人妻之人人| 国产精选无码AV| 欧美ss天堂| 人人操夜夜操夜夜夜漫长| 亚洲性生活免费| 欧美真人无码-二三区| 久久看片婷婷| 在线精品免费不卡中文| 五月天在线国产不卡视频| 艾秋麻豆剧天美传媒| 欧美区一区二护士| 精品无码毛片免费| 阴蒂午夜视频| 国产剧情久无码专区AV| 日本一区二区精彩视频网站| 国产一区二区精品久久蜜臀| 自拍偷拍美女插入| 国产精品99久久免费黑人人妻| 欧美日韩亚洲视频二区久久| 亚洲人成网站在线观看2017| 国内一区二区三区不卡| 三优视频无码又粗又大| 插美妇野嫩逼| 欧美日韩亚洲第一| 无 码人妻在线| 入B无码视频网站| 国产精品性爱视频免费看| 偷拍区 自拍区| 精品欧美黄| www.久久.com| 欧美日韩在线乱码中文字幕| YY久久精品一区|