當前位置:首頁 » 編程語言 » sqlserver添加索引

sqlserver添加索引

發布時間: 2022-09-05 08:50:30

sqlserver 2008 怎麼建立索引

什麼是索引
拿漢語字典的目錄頁(索引)打比方:正如漢語字典中的漢字按頁存放一樣,SQL Server中的數據記錄也是按頁存放的,每頁容量一般為4K 。為了加快查找的速度,漢語字(詞)典一般都有按拼音、筆畫、偏旁部首等排序的目錄(索引),我們可以選擇按拼音或筆畫查找方式,快速查找到需要的字(詞)。
同理,SQL Server允許用戶在表中創建索引,指定按某列預先排序,從而大大提高查詢速度。
• SQL Server中的數據也是按頁( 4KB )存放
• 索引:是SQL Server編排數據的內部方法。它為SQL Server提供一種方法來編排查詢數據。
• 索引頁:資料庫存儲索引的數據頁;索引頁類似於漢語字(詞)典中按拼音或筆畫排序的目錄頁。
• 索引的作用:通過使用索引,可以大大提高資料庫的檢索速度,改善資料庫性能。

索引類型
• 唯一索引:唯一索引不允許兩行具有相同的索引值
• 主鍵索引:為表定義一個主鍵將自動創建主鍵索引,主鍵索引是唯一索引的特殊類型。主鍵索引要求主鍵中的每個值是唯一的,並且不能為空
• 聚集索引(Clustered):表中各行的物理順序與鍵值的邏輯(索引)順序相同,每個表只能有一個
• 非聚集索引(Non-clustered):非聚集索引指定表的邏輯順序。數據存儲在一個位置,索引存儲在另一個位置,索引中包含指向數據存儲位置的指針。可以有多個,小於249個

索引類型:再次用漢語字典打比方,希望大家能夠明白聚集索引和非聚集索引這兩個概念。

唯一索引:
唯一索引不允許兩行具有相同的索引值。
如果現有數據中存在重復的鍵值,則大多數資料庫都不允許將新創建的唯一索引與表一起保存。當新數據將使表中的鍵值重復時,資料庫也拒絕接受此數據。例如,如果在stuInfo表中的學員員身份證號(stuID) 列上創建了唯一索引,則所有學員的身份證號不能重復。
提示:創建了唯一約束,將自動創建唯一索引。盡管唯一索引有助於找到信息,但為了獲得最佳性能,建議使用主鍵約束或唯一約束。

主鍵索引:
在資料庫關系圖中為表定義一個主鍵將自動創建主鍵索引,主鍵索引是唯一索引的特殊類型。主鍵索引要求主鍵中的每個值是唯一的。當在查詢中使用主鍵索引時,它還允許快速訪問數據。

聚集索引(clustered index)
在聚集索引中,表中各行的物理順序與鍵值的邏輯(索引)順序相同。表只能包含一個聚集索引。例如:漢語字(詞)典默認按拼音排序編排字典中的每頁頁碼。拼音字母a,b,c,d……x,y,z就是索引的邏輯順序,而頁碼1,2,3……就是物理順序。默認按拼音排序的字典,其索引順序和邏輯順序是一致的。即拼音順序較後的字(詞)對應的頁碼也較大。如拼音「ha」對應的字(詞)頁碼就比拼音「ba」 對應的字(詞)頁碼靠後。

非聚集索引(Non-clustered)
如果不是聚集索引,表中各行的物理順序與鍵值的邏輯順序不匹配。聚集索引比非聚集索引(nonclustered index)有更快的數據訪問速度。例如,按筆畫排序的索引就是非聚集索引,「1」畫的字(詞)對應的頁碼可能比「3」畫的字(詞)對應的頁碼大(靠後)。
提示:SQL Server中,一個表只能創建1個聚集索引,多個非聚集索引。設置某列為主鍵,該列就默認為聚集索引

如何創建索引
使用T-SQL語句創建索引的語法:
CREATE [UNIQUE] [CLUSTERED|NONCLUSTERED]
INDEX index_name
ON table_name (column_name…)
[WITH FILLFACTOR=x]
q UNIQUE表示唯一索引,可選
q CLUSTERED、NONCLUSTERED表示聚集索引還是非聚集索引,可選
q FILLFACTOR表示填充因子,指定一個0到100之間的值,該值指示索引頁填滿的空間所佔的百分比

在stuMarks表的writtenExam列創建索引:
USE stuDB
GO
IF EXISTS (SELECT name FROM sysindexes
WHERE name = 'IX_writtenExam')
DROP INDEX stuMarks.IX_writtenExam
/*--筆試列創建非聚集索引:填充因子為30%--*/
CREATE NONCLUSTERED INDEX IX_writtenExam
ON stuMarks(writtenExam)
WITH FILLFACTOR= 30
GO
/*-----指定按索引 IX_writtenExam 查詢----*/
SELECT * FROM stuMarks (INDEX=IX_writtenExam)
WHERE writtenExam BETWEEN 60 AND 90
雖然我們可以指定SQL Server按哪個索引進行數據查詢,但一般不需要我們人工指定。SQL Server將會根據我們創建的索引,自動優化查詢。

索引的優缺點
• 優點
– 加快訪問速度
– 加強行的唯一性
• 缺點
– 帶索引的表在資料庫中需要更多的存儲空間
– 操縱數據的命令需要更長的處理時間,因為它們需要對索引進行更新

創建索引的指導原則
• 請按照下列標准選擇建立索引的列。
– 該列用於頻繁搜索
– 該列用於對數據進行排序
• 請不要使用下面的列創建索引:
– 列中僅包含幾個不同的值。
– 表中僅包含幾行。為小型表創建索引可能不太劃算,因為SQL Server在索引中搜索數據所花的時間比在表中逐行搜索所花的時間更長

㈡ sqlserver2014創建索引和刪除索引的方法

在使用sql
server資料庫系統的網友們都知道,一個好的資料庫系統裡面如果缺少索引,那麼這個資料庫就不算是一個完整的資料庫系統,因為資料庫系統是用來存放數據的,索引就像標簽一樣,用戶通過索引可以快速的找到自己想要的東西。接下來小編要講的兩個問題是,第一sql
server2014怎麼創建索引第二個是sqlserver2014刪除索引的方法。
sql
server2014怎麼創建索引:
ALTER
TABLE
`table_name`
ADD
INDEX
index_name
(
`column`
)
1、下面演示下user表的name欄位添加一個索引
2、主鍵索引
添加PRIMARY
KEY
ALTER
TABLE
`table_name`
ADD
PRIMARY
KEY
(
`column`
)
3、唯一索引
添加UNIQUE
ALTER
TABLE
`table_name`
ADD
UNIQUE
(
`column`
)
4、全文索引
添加FULLTEXT
ALTER
TABLE
`table_name`
ADD
FULLTEXT
(
`column`)
5、如何添加多列索引
ALTER
TABLE
`table_name`
ADD
INDEX
index_name
(
`column1`,
`column2`,
`column3`
)
sqlserver2014刪除索引方法:
可利用ALTER
TABLE或DROP
INDEX語句來刪除索引。類似於CREATE
INDEX語句,DROP
INDEX可以在ALTER
TABLE內部作為一條語句處理,語法如下。
DROP
INDEX
index_name
ON
talbe_name
ALTER
TABLE
table_name
DROP
INDEX
index_name
ALTER
TABLE
table_name
DROP
PRIMARY
KEY
其中,前兩條語句是等價的,刪除掉table_name中的索引index_name。
第3條語句只在刪除PRIMARY
KEY索引時使用,因為一個表只可能有一個PRIMARY
KEY索引,因此不需要指定索引名。如果沒有創建PRIMARY
KEY索引,但表具有一個或多個UNIQUE索引,則MySQL將刪除第一個UNIQUE索引。
如果從表中刪除了某列,則索引會受到影響。對於多列組合的索引,如果刪除其中的某列,則該列也會從索引中刪除。如果刪除組成索引的所有列,則整個索引將被刪除。
總結:如果有網友在用sql資料庫系統時,遇到索引之類的問題可以查看小編的教程希望可以給網友們提供有效幫助哈哈!!

㈢ 如何對表進行建立索引sqlserver

可以使用設計器或者語句來建立索引

--創建聚集/非聚集索引
create[clustered][nonclustered]indexidx_nameontable(columna)
--clustered聚集索引
--nonclustered非聚集索引
--idx_name你的索引名稱

㈣ sqlserver。如何在一個表上添加多個索引,都知道單個添加時比較耗時。哪位大師出來指點下哇。感激不盡

每張表可以建立一個聚集索引,不夠用的話,根據實際情況增加非聚集索引。

BEGIN
CREATENONCLUSTEREDINDEXIX_User_User_ID
ONdbo.User(User_ID)
WITHFILLFACTOR=30

--說明:
--IX_User_User_ID索引名稱
--dbo.User創建索引的表名
--User_ID創建索引的欄位
--WITHFILLFACTOR=30表示填充因子,0到100表示索引頁填充的百分比
END

㈤ sqlserver怎麼為表添加索引怎麼用

可以用create index創建索引,如create index test_idx on tablename(col1,col2)
系統優化時會自動選擇使整個查詢開銷最小的查詢計劃。如你的sql 為select * from tablename where col1 = @col1 and col2 = @col2 時一般都會用到索引。

㈥ SQLSERVER 怎樣 加索引 能顯著提高速度

SQLSERVER 怎樣 加索引 能顯著提高速度
1、評估索引本身的佔用空間,當索引相對於其數據本身過大可能會無明顯作用。這種情況
體現在:表很小,索引列過多,索引碎片過多。當索引在select 中不起作用時,你還必須
在insert 和update、delete 這些操作中去維護這些不起作用的數據。
2、In 語句不一定不能使用索引,where id in(1,2)和where id =1 or id=2是等效的,這
里的in 和not in 的性能是相同的。而不能使用索引的原因是嵌套查詢: where id in(sel
ect 1 union select 2).

㈦ 索給用戶表編號列添加唯一索引

以sqlserver為例,創建唯一索引的語法如下:
CREATE UNIQUE CLUSTERED INDEX 索引名 ON 表名(欄位名);
如,為USER表中的id欄位創建唯一索引:
CREATE UNIQUE CLUSTERED INDEX u_id ON USER(USER_CODE);

㈧ sqlserver為某個欄位添加identity自增後,還有必要添加索引嗎該自增列是否自帶索引

你好,很高興回答你的問題。
自增和索引是不同的東西,所以還是要按需要再建索引的。
如果有幫助到你,請點擊採納。

㈨ 如何創建SqlServer視圖的索引

這樣一來,可從索引視圖檢索數據而無需重新編碼,由此帶來的高效率也使現有查詢獲益。在視圖上創建的第一個索引必須是唯一聚集索引。在創建唯一聚集索引後,可創建其它非聚集索引。視圖上的索引命名規則與表上的索引命名規則相同。唯一區別是表名由視圖名替換。(Sql Server聯機幫助)
語句:Create VIEW vXXX WITH SCHEMABINDING AS……
Create UNIQUE CLUSTERED INDEX idxXXX ON vXXX(cXXX)
一個標准視圖轉換為一個索引視圖必須遵守以下規則:
A.視圖必須使用With Schemabinding選項來創建;
如果創建視圖時沒有with Schemabinding,試圖創建視圖時就會報錯:……因為該視圖未綁定到架構
B.在這個視圖中不能使用其他視圖、導出表、行集函數或自查詢,也就是說只能使用表;
C.視圖所用到的基本表必須和視圖屬於同一個所有者;
D.視圖只能鏈接同一個資料庫中的表;
E.視圖不能包含一個外部鏈接或自鏈接,也就是說在鏈接表時只能使用INNER JOIN並且INNER JOIN前後不能使同一個表,不能使用LEFT(RIGHT) JOIN 或者 LEFT (RIGHT) OUTER JOIN ;
F. 視圖不能包含UNION子句、TOP子句、ORDER BY子句、Having子句、Rollup子句、Cube子句、compute子句、Compute By子句或Distinct關鍵字;
G. 視圖不允許使用某些集合函數,如:Count(*)可以使用count_big(*)代替、avg()、max()、min()、stdev()、stdevp()、var()或varp()等;
H. 視圖不能使用Select * 這樣的語句,也就是說視圖的所有欄位都必須顯示指定;
I. 視圖不能包含Text、ntext、image類型的列;
J. 如果視圖包含一個Group By子句,那麼他必須在Select列中包含count_big(*);
K. 視圖中的所有標和用戶自定義的函數都必須使用兩段式名來引用,即所有者.表或函數名稱;
L. 所有的基本表和視圖都必須使用 Set Ansi_Nulls On 創建;
M. 在創建索引時或創建索引後執行IUD時,必須顯示或隱式地執行:
Set ANSI_NULLS ON
SET ANSI_PADDING ON
SET ANSI_WARNINGS ON
SET ARITHABORT ON
SET CONCAT_NULL_YIELDS_NULL ON
SET QUOTED_IDENTIFIER ON
SET NUMERIC_ROUNDABORT OFF
各個選項的有關信息或意義,可以查閱SQL Server的聯機叢書,這里就不再介紹了;
N. 索引視圖只有在SQL Server2000的企業版或開發版或者更高的版本中才能創建。

㈩ 如何創建唯一索引

例如,如果計劃頻繁查詢 employee 表中(其中主鍵為 emp_id)的身份證號碼 (ssn)列,並希望確保身份證號碼是唯一的,則可以在 ssn 上創建唯一索引。如果用戶為一個以上的雇員輸入相同的身份證號碼,則資料庫將顯示錯誤而且無法保存該表。在創建或修改唯一索引時,可以可設置一個忽略重復鍵的選項。如果此選項已設置為「是」,當您試圖通過添加影響多行的數據來創建重復鍵(使用 INSERT 語句)時,則不會添加包含重復項的行;如果此選項設置為「否」,則整個插入操作將失敗,並且將回滾所有數據。 創建唯一索引 在對象資源管理器中,右鍵單擊表,再單擊「設計」。此時,將在表設計器中打開該表。在表設計器菜單上,單擊「索引/鍵」。單擊「添加」。「選定的主/唯一鍵或索引」列表將顯示新索引的系統分配名稱。在網格中,單擊「類型」。從屬性右側的下拉列表中選擇「索引」。在「列」下,選擇要編制索引的列。最多可選擇 16 列。為獲得最佳的性能,請只為每個索引選擇一列或兩列。對於所選的每一列,指定索引是以升序還是以降序來排列此列的值。在網格中,單擊「是唯一的」。從屬性右側的下拉列表中選擇「是」。如果希望忽略會在唯一索引中創建重復鍵(用 INSERT 語句)的數據,請選擇「忽略重復鍵」選項並選擇「是」。在保存表或關系圖時將在資料庫中創建該索引。注意:如果單個列在多行中包含 NULL,則無法對該列創建唯一索引。同樣,如果列的組合在多行中包含 NULL,則無法對多個列創建唯一索引。在進行索引時,它們都被視為重復值。

熱點內容
javaequals方法 發布:2025-07-05 01:57:23 瀏覽:97
sqlsever外鍵 發布:2025-07-05 01:41:04 瀏覽:737
鳳凰衛士加密軟體 發布:2025-07-05 01:39:36 瀏覽:635
桌面軟體編程 發布:2025-07-05 01:32:17 瀏覽:992
編譯後的程序叫啥擴展名是啥 發布:2025-07-05 01:18:29 瀏覽:164
強轉編程 發布:2025-07-05 01:09:50 瀏覽:886
vsgcc編譯器 發布:2025-07-05 00:48:03 瀏覽:903
長城h6第三代都有哪些配置 發布:2025-07-05 00:39:25 瀏覽:397
unix系統編程手冊 發布:2025-07-05 00:32:17 瀏覽:287
重慶壓縮機廠 發布:2025-07-05 00:14:53 瀏覽:758