2012年7月23日 星期一

如何在 MySQL中找到 SQL 瓶頸 - 利用 show profiles


寫資料庫程式時,常需要對 SQL 語法做效能調教,我發現 MySQL 的 profiling 還不錯。

1. 檢查是否有開啟 profiling 功能 (預設是關閉的)
mysql> select @@profiling;
+-------------+
| @@profiling |
+-------------+
|           0 |
+-------------+
1 row in set (0.00 sec)

2. 開啟 profiling 功能
mysql> set profiling=1;
Query OK, 0 rows affected (0.00 sec)

mysql> select @@profiling;
+-------------+
| @@profiling |
+-------------+
|           1 |
+-------------+
1 row in set (0.00 sec)

3. 執行需要測試的 SQL
mysql> SELECT xxx FROM tbl WHERE id=123

4. 檢視效能資料
mysql> show profiles;

mysql> show profile for query 1;

5. 關閉 profiling 功能
mysql> set profiling=0;
Query OK, 0 rows affected (0.00 sec)

mysql> select @@profiling;
+-------------+
| @@profiling |
+-------------+
|           0 |
+-------------+
1 row in set (0.00 sec)

2 則留言:

  1. 777 Casino
    777 Casino is 토토 배당률 보기 located 룰렛 게임 in the heart of downtown Las e sport Vegas, a neighborhood 야동 사이트 순위 that is home to a host of gaming excitement. 룰렛 With over 2,300 of the hottest slots

    回覆刪除
  2. Wynn Las Vegas - MapyRO
    3131 South Las Vegas Blvd, Las Vegas, NV 89109. Directions · (702) 770-1000. Call Now · More Info. Hours, Accepts Credit Cards, Wi-Fi, 보령 출장마사지 Attire, PokéStop,  Rating: 4 · ‎220 reviews · ‎Price 양산 출장샵 range: $$$How is 광주광역 출장마사지 Wynn Las Vegas rated?What days are Wynn Las 구리 출장마사지 Vegas 파주 출장안마 open?

    回覆刪除