文章詳情頁
mysql優化的常用方法有哪些??
瀏覽:129日期:2022-06-17 09:57:37
問題描述
不適用memcahe和redis這些?單從表和字段的設計,包括怎么提高查詢速度呢???
問題解答
回答1:字段優化VARCHAR 長度不要分配太多, 夠用就好
盡量使用 TINYINT、SMALLINT、MEDIUM_INT 作為整數類型而非 INT
使用枚舉或整數代替字符串類型
盡量不要使用 NULL 字段, 因為可能會導致索引失效
盡量使用 TIMESTAMP而非 DATETIME, 因為 TIMESTAMP 只占用4字節, 而 DATETIME 占用8字節.
添加索引對頻繁查詢的字段添加索引.
不要在 WHERE 中對字段進行 NULL 值判斷, 否則將導致引擎放棄使用索引而進行全表掃描
建立索引的字段需要有盡可能大的區分度. 像 性別 這樣的字段, 只有兩個值的, 就不要建索引了.
注意最左前綴匹配原則.
回答2:設置開啟慢查詢日志,用explain分析sql語句,explain extended分析show warnings查看mysql優化器內部改寫的sql語句等等,高性能mysql這本書上有介紹,可以看看
相關文章:
1. 如何解決docker宿主機無法訪問容器中的服務?2. 前端 - CSS3 box-shadow如何設置,或者用什么方法可以產生圖中這樣陰影的效果。3. node.js - vue-cll+sass 樣式不出來 已經npm install sass、 sass-loader了4. html - css 如何讓文字標題顯示在邊框上?5. docker 下面創建的IMAGE 他們的 ID 一樣?這個是怎么回事????6. 在應用配置文件 app.php 中找不到’route_check_cache’配置項7. html按鍵開關如何提交我想需要的值到數據庫8. vim中編輯HTML文件時換行不能縮進9. HTML5中怎么判斷用戶是否正在瀏覽頁面?10. html - 微信端video標簽播放mp4視頻,安卓端提示視頻解析錯誤
排行榜
