首頁 資料庫 mysql教程 分享mysql資料庫常見的最佳化操作

分享mysql資料庫常見的最佳化操作

Apr 30, 2017 am 10:16 AM
mysql 最佳化 資料庫

這篇文章主要為大家介紹了關於mysql資料庫常見的最佳化操作,文章總結的都是個人日常開發使用mysql資料庫的經驗所得,其中包括Index索引、少用SELECT*、EXPLAIN SELECT以及開啟查詢快取等相關資料,相信會對大家有一定的參考價值,需要的朋友們下面來一起看看吧。

前言

對於一個以資料為中心的應用,資料庫的好壞直接影響到程式的效能,因此資料庫效能至關重要。所以mysql資料庫的最佳化操作大家都要有所了解,本文就主要總結了mysql資料庫中常見的最佳化操作,下面話不多說了,來看看詳細的介紹吧。

一、Index索引

將Index放第一位,不用說,這種優化方式我們一直都在悄悄使用,那便是主鍵索引。有時候我們可能並不在意,如果定義適合的索引,資料庫查詢效能(速度)將提高幾倍甚至幾十倍。

普通索引

作用是提高查詢速度。

建表,建立索引

CREATE TABLE tbl_name(
字段名称 字段类型 [完整性约束条件],
~
index [索引名] (column_name)
);
登入後複製

建立索引

CREATE INDEX index_name ON tab_name (column_name)
登入後複製

刪除索引

DROP INDEX index_name FROM tab_name
登入後複製

查看索引

SHOW index FROM tab_name
登入後複製

主鍵索引

作用是加速查詢和唯一約束

建表,建立索引

CREATE TABLE tbl_name(
字段名称 字段类型 [完整性约束条件],
~
PRIMARY KEY(column_name)
);
登入後複製

建立索引

ALTER TABLE tab_name ADD PRIMARY KEY(column_name)
登入後複製

刪除索引

ALTER TABLE tab_name DROP PRIMAY KEY(column_name)
登入後複製

唯一索引

作用是加速查詢和唯一約束

建表,建立索引

CREATE TABLE tbl_name(
字段名称 字段类型 [完整性约束条件],
~
unique [索引名] (column_name)
);
登入後複製

建立索引

CREATE UNIQUE INDEX index_name ON tab_name (column_name)
登入後複製

刪除索引

DROP UNIQUE INDEX index_name FROM tab_name
登入後複製

二、少用SELECT*

#可能有的人查詢資料庫時,遇到要查詢的都會select,這是不恰當的行為。我們應該取我們要使用的數據,而不是全取,因為當我們select時,會增加web伺服器的負擔,增加網路傳輸的負載,查詢速度自然就下降 。

三、EXPLAIN SELECT

#對於這個功能估計很多人都沒見過,但這裡強烈建議使用。 explain顯示了mysql如何使用索引來處理select語句以及連接表。可以幫助選擇更好的索引和寫出更優化的查詢語句。主要用髮就是在select前加上explain即可。

EXPLAIN SELECT [查找字段名] FROM tab_name ...
登入後複製

四、開啟查詢快取

#大多數的MySQL伺服器都開啟了查詢快取。這是提高性最有效的方法之一,而且這是由MySQL的資料庫引擎處理的。當有很多相同的查詢被執行了多次的時候,這些查詢結果會被放到一個快取中,這樣,後續的相同的查詢就不用操作表而直接存取快取結果了。

第一步驟把query_cache_type設定為ON,然後查詢系統變數have_query_cache是​​否可用:

show variables like 'have_query_cache'
登入後複製

之後,分配記憶體大小給查詢緩存,控制緩存查詢結果的最大值。相關操作在設定檔中進行修改。

五、使用NOT NULL

很多表都包含可為NULL (空值) 的列,即使應用程式井不需要保存NULL 也是如此,這是因為可為NULL 是列的預設屬性。通常情況下最好指定列為 NOT NULL,除非真 的需要儲存 NULL 值。

如果查詢中包含可為 NULL 的列,對 MySQL 來說更難優化 ,因為可為 NULL 的列使 得索引、索引統計和值比較都更複雜 。可為NULL 的欄位會使用更多的儲存空間 ,在 MySQL 裡也需要特殊處理 。當可為NULL 的列被索引肘,每個索引記錄需要一個額 外的字節,在 MyISAM 裡甚至還可能導致固定大小 的索引 (例如只有一個整數列的 索引) 變成可變大小的索引。

通常會將可為NULL 的列改為NOT NULL 所帶來的效能提升比較小,所以(調優時) 沒有必要先在現有schema中找出井修改掉這種情況,除非確定這會導致問題。但是, 如果計劃在列上建立索引 ,就應該盡量避免設計成可為 NULL 的欄位。當然也有例外 ,例如值得一提的是,InnoDB 使用單獨的位元 (bit ) 儲存 NULL 值 ,所 以對於稀疏資料由有很好的空間效率 。但這一點不適用於MyISAM 。

六、儲存引擎的選擇

对于如何选择MyISAM和InnoDB,如果你需要事务处理或是外键,那么InnoDB可能是比较好的方式。如果你需要全文索引,那么通常来说MyISAM是好的选择,因为这是系统内建的,然而,我们其实并不会经常地去测试两百万行记录。所以,就算是慢一点,我们可以通过使用Sphinx从InnoDB中获得全文索引。

数据的大小,是一个影响你选择什么样存储引擎的重要因素,大尺寸的数据集趋向于选择InnoDB方式,因为其支持事务处理和故障恢复。数据库的在小决定了故障恢复的时间长短,InnoDB可以利用事务日志进行数据恢复,这会比较快。而MyISAM可能会需要

几个小时甚至几天来干这些事,InnoDB只需要几分钟。

您操作数据库表的习惯可能也会是一个对性能影响很大的因素。比如: COUNT() 在 MyISAM表中会非常快,而在InnoDB表下可能会很痛苦。而主键查询则在InnoDB下会相当相当的快,但需要小心的是如果我们的主键太长了也会导致性能问题。大批的inserts语句在MyISAM下会快一些,但是updates在InnoDB 下会更快一些——尤其在并发量大的时候。

所以,到底你检使用哪一个呢?根据经验来看,如果是一些小型的应用或项目,那么MyISAM也许会更适合。当然,在大型的环境下使用MyISAM也会有很大成功的时候,但却不总是这样的。如果你正在计划使用一个超大数据量的项目,而且需要事务处理或外键支持,那么你真的应该直接使用InnoDB方式。但需要记住InnoDB的表需要更多的内存和存储,转换100GB的MyISAM 表到InnoDB 表可能会让你有非常坏的体验。

七、避免在 where 子句中使用 or 来连接

如果一个字段有索引,一个字段没有索引,将导致引擎放弃使用索引而进行全表扫描,如:

select id from t where num=10 or Name = 'admin'
登入後複製

可以这样查询:

select id from t where num = 10
union all
select id from t where Name = 'admin'
登入後複製

八、多使用varchar/nvarchar

使用varchar/nvarchar代替 char/nchar ,因为首先变长字段存储空间小,可以节省存储空间,其次对于查询来说,在一个相对较小的字段内搜索效率显然要高些。

九、避免大数据量返回

这里要考虑使用limit,来限制返回的数据量,如果每次返回大量自己不需要的数据,也会降低查询速度。

十、where子句优化

where 子句中使用参数,会导致全表扫描,因为SQL只有在运行时才会解析局部变量,但优化程序不能将访问计划的选择推迟到运行时;它必须在编译时进行选择。然 而,如果在编译时建立访问计划,变量的值还是未知的,因而无法作为索引选择的输入项。

应尽量避免在 where 子句中对字段进行表达式操作,避免在where子句中对字段进行函数操作这将导致引擎放弃使用索引而进行全表扫描。不要在 where 子句中的“=”左边进行函数、算术运算或其他表达式运算,否则系统将可能无法正确使用索引。


以上是分享mysql資料庫常見的最佳化操作的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
威爾R.E.P.O.有交叉遊戲嗎?
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

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

mysql:簡單的概念,用於輕鬆學習 mysql:簡單的概念,用於輕鬆學習 Apr 10, 2025 am 09:29 AM

MySQL是一個開源的關係型數據庫管理系統。 1)創建數據庫和表:使用CREATEDATABASE和CREATETABLE命令。 2)基本操作:INSERT、UPDATE、DELETE和SELECT。 3)高級操作:JOIN、子查詢和事務處理。 4)調試技巧:檢查語法、數據類型和權限。 5)優化建議:使用索引、避免SELECT*和使用事務。

phpmyadmin怎麼打開 phpmyadmin怎麼打開 Apr 10, 2025 pm 10:51 PM

可以通過以下步驟打開 phpMyAdmin:1. 登錄網站控制面板;2. 找到並點擊 phpMyAdmin 圖標;3. 輸入 MySQL 憑據;4. 點擊 "登錄"。

MySQL:世界上最受歡迎的數據庫的簡介 MySQL:世界上最受歡迎的數據庫的簡介 Apr 12, 2025 am 12:18 AM

MySQL是一種開源的關係型數據庫管理系統,主要用於快速、可靠地存儲和檢索數據。其工作原理包括客戶端請求、查詢解析、執行查詢和返回結果。使用示例包括創建表、插入和查詢數據,以及高級功能如JOIN操作。常見錯誤涉及SQL語法、數據類型和權限問題,優化建議包括使用索引、優化查詢和分錶分區。

為什麼要使用mysql?利益和優勢 為什麼要使用mysql?利益和優勢 Apr 12, 2025 am 12:17 AM

選擇MySQL的原因是其性能、可靠性、易用性和社區支持。 1.MySQL提供高效的數據存儲和檢索功能,支持多種數據類型和高級查詢操作。 2.採用客戶端-服務器架構和多種存儲引擎,支持事務和查詢優化。 3.易於使用,支持多種操作系統和編程語言。 4.擁有強大的社區支持,提供豐富的資源和解決方案。

redis怎麼使用單線程 redis怎麼使用單線程 Apr 10, 2025 pm 07:12 PM

Redis 使用單線程架構,以提供高性能、簡單性和一致性。它利用 I/O 多路復用、事件循環、非阻塞 I/O 和共享內存來提高並發性,但同時存在並發性受限、單點故障和不適合寫密集型工作負載的局限性。

MySQL和SQL:開發人員的基本技能 MySQL和SQL:開發人員的基本技能 Apr 10, 2025 am 09:30 AM

MySQL和SQL是開發者必備技能。 1.MySQL是開源的關係型數據庫管理系統,SQL是用於管理和操作數據庫的標準語言。 2.MySQL通過高效的數據存儲和檢索功能支持多種存儲引擎,SQL通過簡單語句完成複雜數據操作。 3.使用示例包括基本查詢和高級查詢,如按條件過濾和排序。 4.常見錯誤包括語法錯誤和性能問題,可通過檢查SQL語句和使用EXPLAIN命令優化。 5.性能優化技巧包括使用索引、避免全表掃描、優化JOIN操作和提升代碼可讀性。

MySQL的位置:數據庫和編程 MySQL的位置:數據庫和編程 Apr 13, 2025 am 12:18 AM

MySQL在數據庫和編程中的地位非常重要,它是一個開源的關係型數據庫管理系統,廣泛應用於各種應用場景。 1)MySQL提供高效的數據存儲、組織和檢索功能,支持Web、移動和企業級系統。 2)它使用客戶端-服務器架構,支持多種存儲引擎和索引優化。 3)基本用法包括創建表和插入數據,高級用法涉及多表JOIN和復雜查詢。 4)常見問題如SQL語法錯誤和性能問題可以通過EXPLAIN命令和慢查詢日誌調試。 5)性能優化方法包括合理使用索引、優化查詢和使用緩存,最佳實踐包括使用事務和PreparedStatemen

怎樣建立sql數據庫 怎樣建立sql數據庫 Apr 09, 2025 pm 04:24 PM

構建 SQL 數據庫涉及 10 個步驟:選擇 DBMS;安裝 DBMS;創建數據庫;創建表;插入數據;檢索數據;更新數據;刪除數據;管理用戶;備份數據庫。

See all articles