通過建立索引解決MySQL資料庫查詢慢的問題
阿新 • • 發佈:2019-02-11
當前有一個表是從12366的orcale資料庫裡抽取過來的,原orcale資料庫裡面有三個clob欄位,轉化到MySQL為longtext型別,資料大約有三萬條資料,但是查詢的時候卻要10來秒,實在影響效率,經過詢問,要建索引,SQL如下:
ALTER TABLE tb_zskzl_info_nr ADD INDEX zskzl_info_nr_index (zlcode)
表結構如下:
建索引前: SELECT * FROM tb_zskzl_info_nr where zlcode='1' 耗時18.31s 建索引後: SELECT * FROM tb_zskzl_info_nr where zlcode='1' 耗時0.023s MySQL索引相關知識: 使用索引是資料庫效能優化的必備技能之一。在MySQL資料庫中,有四種索引:聚集索引(主鍵索引)、普通索引、唯一索引以及我們這裡將要介紹的全文索引(FULLTEXT INDEX)。 1.新增PRIMARY KEY(主鍵索引)
ALTER TABLE `table_name` ADD PRIMARY KEY ( `column` )
2.新增UNIQUE(唯一索引)
ALTER TABLE `table_name` ADD UNIQUE ( `column` )
3.新增INDEX(普通索引)
ALTER TABLE `table_name` ADD INDEX index_name ( `column` )
4.新增FULLTEXT(全文索引)
ALTER TABLE `table_name` ADD FULLTEXT ( `column`)
5.新增多列索引
ALTER TABLE `table_name` ADD INDEX index_name ( `column1`, `column2`, `column3` )
全文索引詳情:
在MySQL中,建立全文索引相對比較簡單。例如,我們有一個文章表(article),其中有主鍵ID(id)、文章標題(title)、文章內容(content)三個欄位。現在我們希望能夠在title和content兩個列上建立全文索引,article表及全文索引的建立SQL語句如下:
--建立article表
CREATE TABLE article (
id INT UNSIGNED AUTO_INCREMENT NOT NULL PRIMARY KEY,
title VARCHAR(200),
content TEXT,
FULLTEXT (title, content) --在title和content列上建立全文索引
);
上面就是在建立表的同時建立全文索引的SQL示例。此外,如果我們想要給已經存在的表的指定欄位建立全文索引,同樣以article表為例,我們可以使用如下SQL語句進行建立:
ALTER TABLE article ADD FULLTEXT INDEX fulltext_article (title, content)
在MySQL中建立全文索引之後,現在就該瞭解如何使用了。眾所周知,在資料庫中進行模糊查詢是使用LIKE關鍵字進行查詢,例如:
SELECT * FROM article WHERE content LIKE '%查詢字串%'
那麼,我們使用全文索引也是這樣用的嗎?當然不是,我們必須使用特有的語法才能使用全文索引進行查詢。例如,我們想要在article表的title和content列中全文檢索指定的查詢字串,可以如下編寫SQL語句:
SELECT * FROM article WHERE MATCH(title, content) AGAINST('查詢字串')
建索引前: SELECT * FROM tb_zskzl_info_nr where zlcode='1' 耗時18.31s 建索引後: SELECT * FROM tb_zskzl_info_nr where zlcode='1' 耗時0.023s MySQL索引相關知識: 使用索引是資料庫效能優化的必備技能之一。在MySQL資料庫中,有四種索引:聚集索引(主鍵索引)、普通索引、唯一索引以及我們這裡將要介紹的全文索引(FULLTEXT INDEX)。 1.新增PRIMARY KEY(主鍵索引)