導航:首頁 > 數據處理 > 如何給資料庫建立索引

如何給資料庫建立索引

發布時間:2022-02-04 19:23:01

資料庫中怎麼建立索引

1.資料庫中的索引分為兩種類型,分別是普通索引、唯一索引。下面讓我們來分別介紹一下這...
2.第一種是普通索引,CREATE INDEX indexName ON mytable(...
3.第二種是唯一索引,它與普通索引是類似的,但也存在不同之處,不同之處在於索引列的值...
4.以上三張圖分別為創建索引、修改表結構、創建表時直接指定的數據。而且還有四種方式來...
5.第一種方式:ALTER TABLE tbl_name ADD PRIMARY KEY (...

Ⅱ 建資料庫是怎樣建索引

CREATE [UNIQUE|FULLTEXT|SPATIAL] INDEX index_name [USING index_type] ON tbl_name (index_col_name,...) index_col_name: col_name [(length)] [ASC | DESC]CREATE INDEX被映射到一個ALTER TABLE語句上,用於創建索引。
CREATE INDEX允許您向已有的表中添加索引。
格式為(col1, col2,...)的一個列清單創建出一個多列索引。通過串接給定列中的值,確定索引值的格式。
對於CHAR和VARCHAR列,只用一列的一部分就可創建索引。創建索引時,使用col_name(length)語法,對前綴編制索引。前綴包括每列值的前length個字元。BLOB和TEXT列也可以編制索引,但是必須給出前綴長度。
此處展示的語句用於創建一個索引,索引使用列名稱的前10個字元。

參考資料: dev.mysql.com/...-index

Ⅲ 資料庫索引怎麼建立

right © 1999-2020, CSDN.NET, All Rights Reserved

程序員必備的瀏覽器插件
登錄

越來越好ing
關注
資料庫索引是什麼,有什麼用,怎麼用 轉載
2018-12-04 23:30:36
5點贊

越來越好ing

碼齡2年

關注
下面是關於資料庫索引的相關知識:

簡單來說,資料庫索引就是資料庫的數據結構!進一步說則是該數據結構中存儲了一張表中某一列的所有值,也就是說索引是基於數據表中的某一列創建的。總而言之:一個索引是由表中某一列上的數據組成,並且這些數據存儲在某個數據結構中。

2.索引的作用。舉個例子,假設有一張數據表Emplyee,該表有三列:

表中有幾萬條記錄。現在要執行下面這條查詢語句,查找出所有名字叫「Jesus」的員工的詳細信息

3.如果沒有資料庫索引功能,資料庫系統會逐行的遍歷整張表,對於每一行都要檢查其Employee_Name欄位是否等於「Jesus」。因為我們要查找所有名字為「Jesus」的員工,所以當我們發現了一條名字是「Jesus」的記錄後,並不能停止繼續查找,因為可能有其他員工也叫「Jesus」。這就意味著,對於表中的幾萬條記錄,資料庫每一條都要檢查。這就是所謂的「全表掃描」( full table scan)

4.而資料庫索引功能索引的最大作用就是加快查詢速度,它能從根本上減少需要掃表的記錄/行的數量。

5.如何創建資料庫索引。可以基於Employee表的兩列創建索引即可:

拓展資料:

索引是對資料庫表中一列或多列的值進行排序的一種結構,使用索引可快速訪問資料庫表中的特定信息。如果想按特定職員的姓來查找他或她,則與在表中搜索所有的行相比,索引有助於更

Ⅳ 我的這個資料庫 應該怎麼建立索引

如果你的表真的就是只有這么幾個欄位和這么多記錄,那建不建索引對效率應該產生不了太大的影響。SQL全在內存里查詢,速度會很快,而且你的查詢語句基本都是列出所有數據,sql基本都要全表掃描了。
真正影響效率的可能是網路。

Ⅳ sql怎麼建立索引

什麼是索引
拿漢語字典的目錄頁(索引)打比方:正如漢語字典中的漢字按頁存放一樣,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在索引中搜索數據所花的時間比在表中逐行搜索所花的時間更長

Ⅵ 資料庫表如何建立索引

可以建立索引的;至於建立聚集索引或者是非聚集索引,那要看你這個時間欄位的具體情況以及使用或變更頻繁程度。 一般來說,適合建立聚集索引的要求:「既不能絕大多數都相同,又不能只有極少數相同」的規則。 先說說一個誤區:有人認為:只要建立索引就能顯著提高查詢速度。這個想法是很錯誤的。建立非聚集索引,確實,一般情況下可以提高速度,但是一般並不會達到你想要的速度。只有在適當的列建立適當的(聚集)索引,才能達到滿意的效果。 下面的表總結了何時使用聚集索引或非聚集索引(很重要)。 動作描述 使用聚集索引 使用非聚集索引 列經常被分組排序 應應 返回某范圍內的數據 應 不應 一個或極少不同值 不應 不應 小數目的不同值 應 不應 大數目的不同值 不應 應 頻繁更新的列 不應 應 外鍵列 應應 主鍵列 應應 頻繁修改索引列 不應 應 別的就要看你的理解了。

Ⅶ 如何為資料庫建立特定的索引

如果你是要深入資料庫設計,那索引怎麼建得從類型學起,如果你只是想處理目前比較棘手的查詢慢的問題,有幾點經驗可以和你分享下

主鍵就是一類索引,所以沒必要再建

另外常用搜索欄位,比如日期,查詢常會有選擇一段時間的數據,對日期就可以用你自己上面設計的索引,能夠加快查詢速度,但前提是這個日期是被你經常用到的查詢條件

如果是初學,建立索引後 你不必去研究它是如何工作的,那會比較難懂,總之建了後,系統會自動優化查詢,提高速度的

Ⅷ 資料庫中怎樣建立索引

不同資料庫索引建法不一樣,所以在這里也很難回答你的問題。你可以在BAIDU里搜索如「oracle建立索引」「SQLSERVER建立索引」等,這方面文章也很多。

Ⅸ 怎麼建立資料庫的索引

PS:索引不是給你使用的,而是資料庫本身使用,索引只是為了讓你的查詢更加快速而已

SQL CREATE INDEX 語法
在表上創建一個簡單的索引。允許使用重復的值:
CREATE INDEX index_name
ON table_name (column_name)

注釋:」column_name」 規定需要索引的列。
SQL CREATE UNIQUE INDEX 語法
在表上創建一個唯一的索引。唯一的索引意味著兩個行不能擁有相同的索引值。
CREATE UNIQUE INDEX index_name
ON table_name (column_name)

CREATE INDEX 實例
本例會創建一個簡單的索引,名為 「PersonIndex」,在 Person 表的 LastName 列:
CREATE INDEX PersonIndex
ON Person (LastName)

如果您希望以降序索引某個列中的值,您可以在列名稱之後添加保留字 DESC:
CREATE INDEX PersonIndex
ON Person (LastName DESC)

假如您希望索引不止一個列,您可以在括弧中列出這些列的名稱,用逗號隔開:
CREATE INDEX PersonIndex
ON Person (LastName, FirstName)12

Ⅹ 資料庫索引怎麼建立

Create index Index_表名_欄位 on 表名 (欄位)

閱讀全文

與如何給資料庫建立索引相關的資料

熱點內容
丹東哪裡有玉石交易市場 瀏覽:358
調取對方身份信息需要多久 瀏覽:692
怎麼查西數硬碟是哪個代理的 瀏覽:93
聚羧酸減水劑技術員主要干什麼 瀏覽:939
玩游戲沒有及時回女生信息怎麼辦 瀏覽:356
反饋信息來源怎麼寫 瀏覽:325
怎麼讓程序運行手機黑屏 瀏覽:683
沈陽市古董市場在哪裡 瀏覽:48
濰柴應用技術支持是什麼 瀏覽:256
港股一天最多交易多少次 瀏覽:248
茵茵怎麼做代理 瀏覽:424
粵康碼場所申報碼數據如何查看 瀏覽:744
如何加強數據開放 瀏覽:248
全球稅務信息透明後會怎麼樣 瀏覽:157
包頭輕工職業技術學院多少分進 瀏覽:219
今年雙十一交易額在多少 瀏覽:423
市場營銷中介包括哪些 瀏覽:838
為什麼英德農產品賣得那麼火 瀏覽:853
在哪些平台如何才能進行外匯交易 瀏覽:618
歷史價格數據怎麼存儲比較好 瀏覽:382