101個MySQL調(diào)試和優(yōu)化技巧(2)_MySQL教程
推薦:在MySQL中使用GTIDs復(fù)制協(xié)議和中斷協(xié)議的教程MySQL5.6有很多新的特性,其中很多人都感興趣的一條就是全局事務(wù)序號功能(GTIDs)。而大家都對這一特性很感興趣的原因也很好理解,即:本來重新連接從服務(wù)器和一個新的主服務(wù)器一直是件很麻煩的事,然而在啟用GTIDs功能之后就變得簡單易行�?墒牵珿TIDs的使用不單單是用
51.檢查和經(jīng)常優(yōu)化表.
52. 經(jīng)常重寫InnoDB表優(yōu)化.
53. 有時,當(dāng)添加列時刪除索引,然后在添加回來索引,這樣就會更快.
54. 針對不同的需求,使用不同的存儲引擎.
55. 使用歸檔存儲引擎日志表或?qū)徲嫳?這是更有效地寫道.
56. 會話數(shù)據(jù)存儲在緩存(memcache)的而不是MySQL中 – 緩存允許自動自動填值的,并阻止您創(chuàng)建難以讀取和寫入到MySQL的時空數(shù)據(jù).
57.存儲可變長度的字符串時使用VARCHAR而不是CHAR – 節(jié)省空間,因為固定長度的CHAR,而VARCHAR長度不固定(UTF8不受此影響).
58. 逐步進行模式的變化 – 一個小的變化,可以有巨大的影響.
59.在開發(fā)環(huán)境中測試所有模式,反映生產(chǎn)變化.
60. 不要隨意更改你的配置文件中的值,它可以產(chǎn)生災(zāi)難性的影響.
61. 有時候,在MySQL的configs少即是多.
62.有疑問時使用一個通用的MySQL配置文件.

查詢優(yōu)化:
63. 使用慢查詢?nèi)罩救グl(fā)現(xiàn)慢查詢。
64. 使用執(zhí)行計劃去判斷查詢是否正常運行。
65. 總是去測試你的查詢看看是否他們運行在最佳狀態(tài)下 –久而久之性能總會變化。
66. 避免在整個表上使用count(*),它可能鎖住整張表。
67. 使查詢保持一致以便后續(xù)相似的查詢可以使用查詢緩存。
68. 在適當(dāng)?shù)那樾蜗率褂肎ROUP BY而不是DISTINCT。
69. 在WHERE, GROUP BY和ORDER BY子句中使用有索引的列。
70. 保持索引簡單,不在多個索引中包含同一個列。
71. 有時候MySQL會使用錯誤的索引,對于這種情況使用USE INDEX。
72. 檢查使用SQL_MODE=STRICT的問題。
73. 對于記錄數(shù)小于5的索引字段,在UNION的時候使用LIMIT不是是用OR.
74. 為了 避免在更新前SELECT,使用INSERT ON DUPLICATE KEY或者INSERT IGNORE ,不要用UPDATE去實現(xiàn)。
75. 不要使用 MAX,使用索引字段和ORDER BY子句。
76. 避免使用ORDER BY RAND().
77. LIMIT M,N實際上可以減緩查詢在某些情況下,有節(jié)制地使用。
78. 在WHERE子句中使用UNION代替子查詢。
79. 對于UPDATES(更新),使用 SHARE MODE(共享模式),以防止獨占鎖。
80. 在重新啟動的MySQL,記得來溫暖你的數(shù)據(jù)庫,以確保您的數(shù)據(jù)在內(nèi)存和查詢速度快。
81. 使用DROP TABLE,CREATE TABLE DELETE FROM從表中刪除所有數(shù)據(jù)。
82. 最小化的數(shù)據(jù)在查詢你需要的數(shù)據(jù),使用*消耗大量的時間。
83. 考慮持久連接,而不是多個連接,以減少開銷。
84. 基準(zhǔn)查詢,包括使用服務(wù)器上的負載,有時一個簡單的查詢可以影響其他查詢。
85. 當(dāng)負載增加您的服務(wù)器上,使用SHOW PROCESSLIST查看慢的和有問題的查詢。
86. 在開發(fā)環(huán)境中產(chǎn)生的鏡像數(shù)據(jù)中 測試的所有可疑的查詢。
MySQL 備份過程:
87. 從二級復(fù)制服務(wù)器上進行備份。
88. 在進行備份期間停止復(fù)制,以避免在數(shù)據(jù)依賴和外鍵約束上出現(xiàn)不一致。
89. 徹底停止MySQL,從數(shù)據(jù)庫文件進行備份。
90. 如果使用 MySQL dump進行備份,請同時備份二進制日志文件 – 確保復(fù)制沒有中斷。
91. 不要信任LVM 快照 – 這很可能產(chǎn)生數(shù)據(jù)不一致,將來會給你帶來麻煩。
92. 為了更容易進行單表恢復(fù),以表為單位導(dǎo)出數(shù)據(jù) – 如果數(shù)據(jù)是與其他表隔離的。
93. 當(dāng)使用mysqldump時請使用 –opt。
94. 在備份之前檢查和優(yōu)化表。
95. 為了更快的進行導(dǎo)入,在導(dǎo)入時臨時禁用外鍵約束。
96. 為了更快的進行導(dǎo)入,在導(dǎo)入時臨時禁用唯一性檢測。
97. 在每一次備份后計算數(shù)據(jù)庫,表以及索引的尺寸,以便更夠監(jiān)控數(shù)據(jù)尺寸的增長。
98. 通過自動調(diào)度腳本監(jiān)控復(fù)制實例的錯誤和延遲。
99. 定期執(zhí)行備份。
100. 定期測試你的備份。
分享:MySQL獲取所有分類的前N條記錄比如有文章表 Article(Id,Category,InsertDate),現(xiàn)在要用SQL找出每種類型中時間最新的前N個數(shù)據(jù)組成的集合,一段不錯的代碼,留存?zhèn)溆?SELECT A1.* FROM Article AS A1 INNER JOIN (SELECT A.Category,A.InsertDate FROM Article AS A LEFT JOIN Article AS B ON A.Ca
MySQL教程Rss訂閱編程教程搜索
MySQL教程推薦
- Mysql下建立用戶授權(quán)權(quán)限例子
- SQL提示Login failed for user#039;sa#039;錯誤的解決方案
- Mysql select in 按id排序?qū)崿F(xiàn)方法
- MySQL從MyISAM引擎轉(zhuǎn)換到InnoDB引擎需要注意的地方
- Mysql字符串字段判斷是否包含某個字符串的2種方法
- Windows環(huán)境下重置mysql密碼操作命令
- 網(wǎng)站模板:利用Shell腳本實現(xiàn)遠程MySQL自動查詢
- 基于一致性hash算法(consistent hashing)的使用詳解
- EXP-00091: Exporting questionable statistics
- 將MySQL的臨時目錄建立在內(nèi)存中的教程
猜你也喜歡看這些
- 淺談Linq To Sql集成數(shù)據(jù)庫語言的優(yōu)劣
- SQL Server 2005安裝實例環(huán)境圖解
- 解讀SQL Server SA權(quán)限最新入侵方法
- 解讀在SQL Server中處理空值時涉及的三個問題
- 為何把你的數(shù)據(jù)庫置于版本控制之下
- 如何快速掌握一些異常精妙的"SQL"語句
- sql2005創(chuàng)建遠程登錄帳戶的sql語句
- 基于Sql Server通用分頁存儲過程的解決方法
- Mssql數(shù)據(jù)庫教程之--SQL Server 2008:傳遞表值參數(shù)
- 讓sql2005運行在獨立用戶下出現(xiàn) WMI 提供程序錯誤的解決方式
- 相關(guān)鏈接:
- 教程說明:
MySQL教程-101個MySQL調(diào)試和優(yōu)化技巧(2)
。