色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

MySQL數據庫性能進行優化三大絕招

  以下的文章主要介紹的是對MySQL數據庫性能進行優化的的幾大絕招,其中包括選取最適用的字段屬性,使用連接(JOIN)來代替子查詢(Sub-Queries),使用聯合(UNION)來代替手動創建的臨時表的內容介紹。

  1.選取最適用的字段屬性
  MySQL可以很好的支持大數據量的存取,但是一般說來,數據庫中的表越小,在它上面執行的查詢也就會越快。因此,在創建表的時候,為了獲得更好的性能,我們可以將表中字段的寬度設得盡可能小。例如,在定義郵政編碼這個字段時,如果將其設置為CHAR(255),顯然給數據庫增加了不必要的空間,甚至使用VARCHAR這種類型也是多余的,因為CHAR(6)就可以很好的完成任務了。同樣的,如果可以的話,我們應該使用MEDIUMINT而不是BIGIN來定義整型字段。另外一個提高效率的方法是在可能的情況下,應該盡量把字段設置為NOT NULL,這樣在將來執行查詢的時候,數據庫不用去比較NULL值。

  對于某些文本字段,例如“省份”或者“性別”,我們可以將它們定義為ENUM類型。因為在MySQL中,ENUM類型被當作數值型數據來處理,而數值型數據被處理起來的速度要比文本類型快得多。這樣,我們又可以提高數據庫的性能。

  2.使用連接(JOIN)來代替子查詢(Sub-Queries)
  MySQL從 4.1開始支持SQL的子查詢。這個技術可以使用 SELECT語句來創建一個單列的查詢結果,然后把這個結果作為過濾條件用在另一個查詢中。例如,我們要將客戶基本信息表中沒有任何訂單的客戶刪除掉,就可以利用子查詢先從銷售信息表中將所有發出訂單的客戶ID取出來,然后將結果傳遞給主查詢,如下所示:

DELETE FROM customerinfo
  WHERE CustomerID NOT
in (SELECT CustomerID FROM salesinfo )

it知識庫MySQL數據庫性能進行優化三大絕招,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 孟州市| 普兰店市| 许昌县| 灵丘县| 呼图壁县| 内黄县| 延川县| 资溪县| 临沭县| 长岭县| 永顺县| 长寿区| 连城县| 丁青县| 遵化市| 金沙县| 高邑县| 信宜市| 九龙县| 贺州市| 绥江县| 梓潼县| 宁陵县| 德安县| 尉氏县| 天台县| 光泽县| 灵武市| 商洛市| 青田县| 沧源| 微山县| 博乐市| 南陵县| 泸水县| 囊谦县| 万山特区| 张北县| 兰溪市| 三河市| 齐齐哈尔市|