国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > MySQL > 正文

MySQL數據庫十大優化技巧

2024-07-24 12:44:34
字體:
來源:轉載
供稿:網友
1.優化你的MySQL查詢緩存

在MySQL服務器上進行查詢,可以啟用高速查詢緩存。讓數據庫引擎在后臺悄悄的處理是提高性能的最有效方法之一。當同一個查詢被執行多次時,如果結果是從緩存中提取,那是相當快的。

但主要的問題是,它是那么容易被隱藏起來以至于我們大多數程序員會忽略它。在有些處理任務中,我們實際上是可以阻止查詢緩存工作的。
復制代碼 代碼如下:

// query cache does NOT work
$r = mysql_query("SELECT username FROM user WHERE signup_date >= CURDATE()");

// query cache works!
$today = date("Y-m-d");
$r = mysql_query("SELECT username FROM user WHERE signup_date >= '$today'");

// query cache does NOT work
$r = mysql_query("SELECT username FROM user WHERE signup_date >= CURDATE()");

// query cache works!
$today = date("Y-m-d");
$r = mysql_query("SELECT username FROM user WHERE signup_date >= '$today'");

2.用EXPLAIN使你的SELECT查詢更加清晰

使用EXPLAIN關鍵字是另一個MySQL優化技巧,可以讓你了解MySQL正在進行什么樣的查詢操作,這可以幫助你發現瓶頸的所在,并顯示出查詢或表結構在哪里出了問題。

EXPLAIN查詢的結果,可以告訴你那些索引正在被引用,表是如何被掃描和排序的等等。

實現一個SELECT查詢(最好是比較復雜的一個,帶joins方式的),在里面添加上你的關鍵詞解釋,在這里我們可以使用phpMyAdmin,他會告訴你表中的結果。舉例來說,假如當我在執行joins時,正忘記往一個索引中添加列,EXPLAIN能幫助我找到問題的所在。

添加之前

添加索引到group_id field后

添加之后

3.利用LIMIT 1取得唯一行

有時,當你要查詢一張表是,你知道自己只需要看一行。你可能會去的一條十分獨特的記錄,或者只是剛好檢查了任何存在的記錄數,他們都滿足了你的WHERE子句。

在這種情況下,增加一個LIMIT 1會令你的查詢更加有效。這樣數據庫引擎發現只有1后將停止掃描,而不是去掃描整個表或索引。

復制代碼 代碼如下:

// do I have any users from Alabama?
// what NOT to do:
$r = mysql_query("SELECT * FROM user WHERE state = 'Alabama'");
if (mysql_num_rows($r) > 0) {
// ...
}
// much better:
$r = mysql_query("SELECT 1 FROM user WHERE state = 'Alabama' LIMIT 1");
if (mysql_num_rows($r) > 0) {
// ...
}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 齐齐哈尔市| 青田县| 当阳市| 巢湖市| 肥城市| 武宁县| 临颍县| 禹州市| 杨浦区| 济源市| 禄丰县| 玛沁县| 沛县| 柳江县| 孝昌县| 萍乡市| 肇东市| 韶山市| 长子县| 乌兰浩特市| 延安市| 溆浦县| 微山县| 建始县| 田阳县| 盐边县| 温泉县| 南汇区| 河西区| 应用必备| 宝山区| 高雄县| 彰化市| 宁夏| 武宣县| 获嘉县| 威信县| 永清县| 铜山县| 开鲁县| 樟树市|