MySQL最佳化之資料類型的使用

來源:互聯網
上載者:User
  1、使你的資料儘可能小
  最基本的最佳化之一是使你的資料(和索引)在磁碟上(並且在記憶體中)佔據的空間儘可能小。這能給出巨大的改進,因為磁碟讀入較快並且通常也用較少的主儲存空間。如果在更小的列上做索引,索引也佔據較少的資源。
  你能用下面的技術使表的效能更好並且使儲存空間最小:
  ·儘可能地使用最有效(最小)的類型。MySQL有很多節省磁碟空間和記憶體的專業化類型。
  ·如果可能使表更小,使用較小的整數類型。例如,MEDIUMINT經常比INT好一些。
  ·如果可能,聲明列為NOT NULL。它使任何事情更快而且你為每列節省一位。注意如果在你的應用程式中你確實需要NULL,你應該毫無疑問使用它,只是避免預設地在所有列上有它。
  2、使用定長列,不使用可變長列
  這條準則對被經常修改,從而容易產生片段的表來說特別重要。例如,應該選擇 CHAR 列而不選擇 VARCHAR 列。所要權衡的是使用定長列時,表所佔用的空間更多,但如果能夠承擔這種空間的耗費,使用定長行將比使用可變長的行處理快得多。
  3、將列定義為 NOT NULL
  這樣處理更快,所需空間更少。而且有時還能簡化查詢,因為不需要檢查是否存在特例 NULL。
  4、考慮使用 ENUM 列
  如果有一個只含有限數目的特定值的列,那麼應該考慮將其轉換為 ENUM 列。ENUM 列的值可以更快地處理,因為它們在內部是以數值表示的。
  有關BLOB和TEXT類型
  1、使用BLOB和TEXT類型的優點
  用 BLOB 儲存應用程式中封裝或未封裝的資料,有可能使原來需要幾個檢索操作才能完成的資料檢索得以在單個檢索操作中完成。而且還對儲存標準表結構不易表示的資料或隨時間變化的資料有協助。
  2、使用BLOB和TEXT類型的可能弊端
  另一方面,BLOB 值也有自己的固有問題,特別是在進行大量的 DELETE 或 UPDATE 操作時更是如此。刪除 BLOB 會在表中留下一個大空白,在以後將需用一個記錄或可能是不同大小的多個記錄來填充。
  除非有必要,否則應避免檢索較大的 BLOB 或 TEXT 值。例如,除非肯定WHERE 子句能夠將結果恰好限制在所想要的行上,否則 SELECT * 查詢不是一個好辦法。這樣做可能會將非常大的 BLOB 值無目的地從網路上拖過來。這是儲存在另一列中的 BLOB 標識資訊很有用的另一種情形。可以搜尋該列以確定想要的行,然後從限定的行中檢索 BLOB 值。
  3、必要的準則
  對容易產生片段的表使用 OPTIMIZE TABLE
  大量進行修改的表,特別是那些含有可變長列的表,容易產生片段。片段不好,因為它在儲存表的磁碟塊中產生不使用的空間。隨著時間的增長,必須讀取更多的塊才能取到有效行,從而降低了效能。任意具有可變長行的表都存在這個問題,但這個問題對 BLOB 列更為突出,因為它們尺寸的變化非常大。經常使用 OPTIMIZE TABLE 有助於保持效能不下降。
  使用多列索引
  多列索引列有時很有用。一種技術是根據其他列建立一個散列值,並將其儲存在一個獨立的列中,然後可通過搜尋散列值找到行。這隻對精確匹配的查詢有效。(散列值對具有諸如“<”或“>=”這樣的操作符的範圍搜尋沒有用處)。在MySQL 3.23版及以上版本中,散列值可利用 MD5( ) 函數產生。散列索引對 BLOB 列特別有用。有一事要注意,在 MySQL 3.23.2 以前的版本中,不能索引 BLOB 類型。甚至是在 3.23.2 或更新的版本中,利用散列值作為標識值來尋找 BLOB 值也比搜尋 BLOB 列本身更快。
  將 BLOB 值隔離在一個獨立的表中
  在某些情況下,將 BLOB 列從表中移出放入另一個副表可能具有一定的意義,條件是移出 BLOB 列後可將錶轉換為定長行格式。這樣會減少主表中的片段,而且能利用定長行的效能優勢。
  使用ANALYSE過程檢查表列
  如果使用的是 MySQL 3.23 或更新的版本,應該執行 PROCEDURE ANALYSE( ),查看它所提供的關於表中列的資訊
  ANALYSE([max elements,[max memory]])
  它檢驗來自你的查詢的結果並返回結果的分析。
  max elements(預設256)是analyse將注意的每列不同值的最大數量。這被ANALYSE用來檢查最佳的列類型是否應該是ENUM類型。
  max memory(預設8192)是在analyse嘗試尋找所有不同值的時候應該分配給每列的最大記憶體量。
  SELECT ... FROM ... WHERE ... PROCEDURE ANALYSE([max elements,[max memory]])
  例如:
  mysql>SELECT * FROM student PROCEDURE ANALYSE();
  mysql>SELECT * FROM student PROCEDURE ANALYSE(16,256);
  相應輸出中有一列是關於表中每列的最佳列類型的建議。第二個例子要求 PROCEDURE ANALYSE( ) 不要建議含有多於 16 個值或取多於 256 位元組的 ENUM 類型(可根據需要更改這些值)。如果沒有這樣的限制,輸出可能會很長;ENUM 的定義也會很難閱讀。(www.3lian.com)
  根據 PROCEDURE ANALYSE( ) 的輸出,會發現可以對錶變更以利用更有效類型。如果希望更改實值型別,使用 ALTER TABLE 語句即可。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.