索引可以提高MySQL的多列LIKE查詢效能嗎?
Dec 13, 2024 am 02:32 AM最佳化 MySQL 中的多列 LIKE 查詢
在多列上使用 LIKE 子句的緩慢 SELECT 查詢可能會成為效能瓶頸。在本文中,我們將探討索引是否可以提高查詢速度並解決有關磁碟使用和插入/刪除效能的問題。
索引可以提高 LIKE 效能嗎?
不幸的是,索引對於 MySQL 中的 LIKE 查詢無效,因為它們透過從左邊開始索引固定數量的字元來運作。使用 LIKE '%text%',目標字串之前可以有任意數量的文本,從而防止使用索引。
替代方法
而不是使用 LIKE,考慮 FTS(全文搜尋)。 MyISAM 表支援 FTS,可以有效搜尋部分字串匹配項。對於非 MyISAM 表,使用單獨的索引表將單字對應到 ID 來實現您自己的索引系統可以複製 FTS 功能。
磁碟使用情況和 INSERT/DELETE 效能
FTS 索引會增加磁碟使用率。但是,對 INSERT/DELETE 操作的影響很小。這是因為插入僅將新單字新增至索引中,這是作為事務的一部分完成的,而刪除標記單字以供以後刪除。
更新
MySQL 5.6引入了對 InnoDB 表的 FTS 支持,為提高各種表類型的 LIKE 性能提供了強大的選項。
以上是索引可以提高MySQL的多列LIKE查詢效能嗎?的詳細內容。更多資訊請關注PHP中文網其他相關文章!
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱門文章
擊敗分裂小說需要多長時間?
3 週前
By DDD
倉庫:如何復興隊友
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前
By 尊渡假赌尊渡假赌尊渡假赌
公眾號網頁更新緩存難題:如何避免版本更新後舊緩存影響用戶體驗?
3 週前
By 王林

熱門文章
擊敗分裂小說需要多長時間?
3 週前
By DDD
倉庫:如何復興隊友
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前
By 尊渡假赌尊渡假赌尊渡假赌
公眾號網頁更新緩存難題:如何避免版本更新後舊緩存影響用戶體驗?
3 週前
By 王林

熱門文章標籤

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

在 Linux 中運行 MySQl(有/沒有帶有 phpmyadmin 的 podman 容器)
