mysql关联查询速度慢的问题及解决
更新时间:2025年03月13日 15:31:52 作者:一个爱看综艺的程序猿
这篇文章主要介绍了mysql关联查询速度慢的问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
mysql关联查询速度慢
1. 记录原因
mysql关联查询速度很慢,是由于字段字符集规则不一致所导致
1.1 在一次线上的服务中
- 发现有几个关联查询速度特别慢,试过了多种优化方案,最后把问题定格在 count() 这个函数
- 由于是分页查询,所以肯定会有count()来去查询记录数,但是每次执行这个count()都会卡住好几秒
1.2 最终发现
- 被关联的两个表 字符集规则不一致,一个是utf8_general_ci,另一个是utf8mb4_0900_ai_ci
- 具体原因可能是因为线上服务器和本地服务器的mysql版本不同导致的,在覆盖的时候出现了问题
2. 解决方案
# 查看各个字段的字符集规则: show full columns from 表名; # 修改字段的字符集: ALTER TABLE 表名 CHANGE 字段名 字段名 VARCHAR(100) CHARACTER SET utf8 COLLATE utf8_general_ci; # 修改表的默认字符集: ALTER TABLE 表名 DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci; # 查看数据库编码: SHOW CREATE DATABASE db_name; # 查看表编码: SHOW CREATE TABLE tbl_name;
3. 具体操作
- 这边我是一个字段一个字段的改 把两个表的字段都统一成了utf8_general_ci格式
ALTER TABLE 表名 CHANGE 字段名 字段名 varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci;
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
通过sysbench工具实现MySQL数据库的性能测试的方法
sysbench是一款压力测试工具,可以测试系统的硬件性能,也可以用来对数据库进行基准测试。这篇文章主要介绍了通过sysbench工具实现MySQL数据库的性能测试 ,需要的朋友可以参考下2019-07-07
innodb_index_stats导入备份数据时报错表主键冲突的解决方法
下面小编就为大家带来一篇innodb_index_stats导入备份数据时报错表主键冲突的解决方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧2017-03-03
MYSQL ERROR 1045 (28000): Access denied for user (using pass
Mysql中添加用户之后可能出现登录时提示ERROR 1045 (28000): Access denied for user的错误.2009-07-07


最新评论