主頁 > 知識庫 > SQLSERVER聚集索引和主鍵(Primary Key)的誤區(qū)認(rèn)識

SQLSERVER聚集索引和主鍵(Primary Key)的誤區(qū)認(rèn)識

熱門標(biāo)簽:承德地圖標(biāo)注公司名需要花錢嗎 慶陽地圖標(biāo)注 浙江穩(wěn)定外呼系統(tǒng)供應(yīng)商 榕城市地圖標(biāo)注 美團地圖標(biāo)注商戶認(rèn)證注冊 咸陽電腦外呼系統(tǒng)運營商 電銷外呼系統(tǒng)軟件功能 北京400電話辦理多少錢 怎么給高德做地圖標(biāo)注
很多人會把Primary Key和聚集索引搞混起來,或者認(rèn)為這是同一個東西。這個概念是非常錯誤的。

主鍵是一個約束(constraint),他依附在一個索引上,這個索引可以是聚集索引,也可以是非聚集索引。
 所以在一個(或一組)字段上有主鍵,只能說明他上面有個索引,但不一定就是聚集索引。
例如下面:
復(fù)制代碼 代碼如下:

USE [pratice]
GO
CREATE TABLE #tempPKCL
(
ID INT PRIMARY KEY CLUSTERED --聚集索引
)
---------------------------------
USE [pratice]
GO
CREATE TABLE #tempPKNCL
(
ID INT PRIMARY KEY NONCLUSTERED --非聚集索引
)
DROP TABLE [#tempPKCL]
DROP TABLE [#tempPKNCL]

如果不加NONCLUSTERED和CLUSTERED關(guān)鍵字,默認(rèn)建的是聚集索引
而一個聚集索引里,是可以有重復(fù)值的。只要他沒有被同時設(shè)為主鍵,但是主鍵不能有重復(fù)值(不管依附在聚集索引上還是非聚集索引上)
強調(diào)這一點,是因為有些人覺得自己的表格上設(shè)置了主鍵,就認(rèn)為表格上有聚集索引,按照B-樹的方式管理了。

如果沒有指定主鍵是個聚集索引,可能表格還是會以堆的方式管理,效率低下
--------------------------------------------------------------------------------
關(guān)于排序和重復(fù)值
排序:建立復(fù)合索引的時候會指定多個字段,那么這個索引順序是按哪個字段順序排序呢?
是按照索引上的第一個字段排序
下面這個索引的排序順序是以ID這個字段排序的
1 CREATE INDEX tempPKNCL_id_ncl ON [dbo].[tempPKNCL]([ID],[a],[c])
重復(fù)值:如果對多列定義了 PRIMARY KEY 約束,則一列中的值可能會重復(fù),但來自 PRIMARY KEY 約束定義中所有列的任何值組合必須唯一。
如下圖所示,Purchasing.ProductVendor 表中的 ProductID 和 VendorID 列構(gòu)成了針對此表的復(fù)合 PRIMARY KEY 約束。
這確保了 ProductID 和 VendorID 的組合是唯一的
 
意思是說,如果是復(fù)合主鍵,那么如果ProductID列有重復(fù),但是 ProductID 和 VendorID 的組合是唯一的
言下之意:
(1)主鍵不是復(fù)合主鍵
(2)主鍵建立在ProductID字段上
(3)ProductID字段有重復(fù)值
那么主鍵建立肯定會失敗
您可能感興趣的文章:
  • SQLServer主鍵和唯一約束的區(qū)別
  • 如何獲取SqlServer2005表結(jié)構(gòu)(字段,主鍵,外鍵,遞增,描述)
  • 深入Mysql,SqlServer,Oracle主鍵自動增長的設(shè)置詳解
  • sqlserver主鍵設(shè)計的注意點
  • sqlserver數(shù)據(jù)庫主鍵的生成方式小結(jié)(sqlserver,mysql)
  • 小議sqlserver數(shù)據(jù)庫主鍵選取策略
  • sqlserver主鍵自增的實現(xiàn)示例

標(biāo)簽:呼和浩特 昭通 新鄉(xiāng) 上海 貴州 江蘇 拉薩 重慶

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《SQLSERVER聚集索引和主鍵(Primary Key)的誤區(qū)認(rèn)識》,本文關(guān)鍵詞  SQLSERVER,聚集,索引,和,主鍵,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《SQLSERVER聚集索引和主鍵(Primary Key)的誤區(qū)認(rèn)識》相關(guān)的同類信息!
  • 本頁收集關(guān)于SQLSERVER聚集索引和主鍵(Primary Key)的誤區(qū)認(rèn)識的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章