文章詳情頁
mysql優化的常用方法有哪些??
瀏覽:176日期: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. boot2docker無法啟動2. docker-compose中volumes的問題3. java - SSH框架中寫分頁時service層中不能注入分頁類4. node.js - antdesign怎么集合react-redux對input控件進行初始化賦值5. 關于docker下的nginx壓力測試6. docker安裝后出現Cannot connect to the Docker daemon.7. 老師,按tab鍵不起作用怎么回事8. dockerfile - 為什么docker容器啟動不了?9. mac里的docker如何命令行開啟呢?10. 關docker hub上有些鏡像的tag被標記““This image has vulnerabilities””
排行榜

網公網安備