MySQL Tuning Summary

來源:互聯網
上載者:User

現在大概列出如下:(望各位補充)

1.資料庫的設計

盡量把資料庫設計的更小的占磁碟空間.
1).儘可能使用更小的整數類型.(mediumint就比int更合適).
2).儘可能的定義欄位為not null,除非這個欄位需要null.(這個規則只適合欄位為KEY的情形)
3).如果沒有用到變長欄位的話比如varchar,那就採用固定大小的紀錄格式比如char.(CHAR 總是比VARCHR快)
4).表的主索引應該儘可能的短.這樣的話每條紀錄都有名字標誌且更高效.
5).只建立確實需要的索引。索引有利於檢索記錄,但是不利於快速儲存記錄。如果總是要在表的組合欄位上做搜尋,那麼就在這些欄位上建立索引。索引的第一部分必須是最常使用的欄位.如果總是需要用到很多欄位,首先就應該多複製這些欄位,使索引更好的壓縮。
(這條只適合MYISAM引擎的表,對於INNODB則在儲存記錄的時候關係不大,因為INNODB是以事務為基礎的,如果想快速儲存記錄的話,特別是大批量的匯入記錄的時候)
6).所有資料都得在儲存到資料庫前進行處理。
7).所有欄位都得有預設值。
8).在某些情況下,把一個頻繁掃描的表分成兩個速度會快好多。在對動態格式表掃描以取得相關記錄時,它可能使用更小的靜態格式表的情況下更是如此。
(具體的表現為:MYISAM表的MERGE類型,以及MYISAM和INNODB通用的分區,詳情見手冊)
9).不會用到外鍵約束的地方盡量不要使用外鍵。

2.系統的用途

1).及時的關閉對MYSQL的串連。
2).explain 複雜的SQL語句。(這樣能確定你的SELECT 語句怎麼最佳化最佳)
3).如果兩個關聯表要做比較話,做比較的欄位必須類型和長度都一致.(在資料龐大的時候建立INDEX)
4).LIMIT語句盡量要跟order by或者 distinct.這樣可以避免做一次full table scan.
5).如果想要清空表的所有紀錄,建議用truncate table tablename而不是delete from tablename.
不過有一個問題,truncate 不會在交易處理中復原。因為她要調用create table 語句。
(Truncate Table 語句先刪除表然後再重建,這個是屬於檔案層級的,所以自然快N多)
實測例子:
song2為INNODB表。
mysql> select count(1) from song2;
+----------+
| count(1) |
+----------+
|   500000 |
+----------+
1 row in set (0.91 sec)

mysql> delete from song2;
Query OK, 500000 rows affected (15.70 sec)
mysql> truncate table song2;
Query OK, 502238 rows affected (0.17 sec)

6).能使用STORE PROCEDURE 或者 USER FUNCTION的時候.(ROUTINE總是減少了伺服器端的開銷)
7).在一條insert語句中採用多重紀錄插入格式.而且使用load data infile來匯入大量資料,這比單純的indert快好多.(在MYSQL中具體表現為:INSERT INTO TABLEQ VALUES (),(),...();)
(還有就是在MYISAM表中插入大量記錄的時候先禁用到KEYS後面再建立KEYS,具體表現語句:
 ALTER TABLE TABLE1 DISABLE KEYS;ALTER TABLE TABLE1 ENABLE KEYS;
而對於INNNODB 表在插入前先 set autocommit=0;完了後:set autocommit=1;這樣效率比較高。)
8).經常OPTIMIZE TABLE 來整理片段.
9).還有就是date 類型的資料如果頻繁要做比較的話盡量儲存在unsigned int 類型比較快。

3.系統的瓶頸

1).磁碟搜尋.
並行搜尋,把資料分開存放到多個磁碟中,這樣能加快搜尋時間.
2).磁碟讀寫(IO)
可以從多個媒介中並行的讀取資料。
3).CPU周期
資料存放在主記憶體中.這樣就得增加CPU的個數來處理這些資料。
4).記憶體頻寬
當CPU要將更多的資料存放到CPU的緩衝中來的話,記憶體的頻寬就成了瓶頸.

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.