Mysql 数据库优化的几个办法_MySQL-mysql教程
作者:大大炮 | 2021-08-27 14:55
Mysql数据库优化的几个办法
1、数据库设计方面,这是 DBA 和 Architect 的责任,设计结构良好的数据库,必要的时候,去正规化(英文是这个: denormalize),允许部分数据冗余,避免 JOIN 操作,以提高查询效率;
2、系统架构设计方面,表散列,把海量数据散列到几个不同的表里面.快慢表,快表只留最新数据,慢表是历史存档.集群,主服务器 Read & write,从服务器 read only, 或者 N 台服务器,各机器互为Master( Mysql 貌似对此支持不是很好);
3、1 和 3 超越 PHP Programmer 的要求了,会更好,不会没关系.检查有没有少加索引(必要时候考虑使用联合索引);
4、写高效的 SQL 语句,看看有没有写低效的SQL语句,比如生成笛卡尔积的全连接啊,大量的 Group By 和 order by,没有 limit 等等.必要的时候,把数据库逻辑封装到DBMS端的存储过程里面.缓存查询结果, explain 每一个 SQL 语句;
5、所得皆必须,只从数据库取必需的数据,比如查询某篇文章的评论数, select count(*) ... where article_id = ? 就可以了,不要先 select * ... where article_id = ?然后 msql_num_rows. 只传送必须的 SQL 语句,比如修改文章的时候,如果用户只修改了标题,那就 update ... set title = ? where article_id = ?不要 set content = ?(大文本);
6、必要的时候用不同的存储引擎.比如 InnoDB 可以减少死锁. HEAP 可以提高一个数量级的查询速度;
推荐阅读
-
如何解决《使用`threadDelay`时系统调用量过大》经验,为你挑选了0个好方法。 ...
[详细]
-
如何解决《如何使用SQL在一个主键中创建2个字段?》经验,为你挑选了1个好方法。 ...
[详细]
-
如何解决《如何在CreateView的form_valid方法中引发错误》经验,为你挑选了1个好方法。 ...
[详细]
-
如何解决《正则表达式4非连续且没有重复数字》经验,为你挑选了1个好方法。 ...
[详细]
-
如何解决《如何为多个项目设置Pycharm》经验,为你挑选了2个好方法。 ...
[详细]
-
如何解决《C#表单身份验证.ASPXAUTHCookie用于SSO》经验,为你挑选了0个好方法。 ...
[详细]
-
如何解决《MVC6WebFarm:无法解密防伪令牌》经验,为你挑选了1个好方法。 ...
[详细]
-
如何解决《通过绑定设置文本时,TextBox删除按钮(小x)不可见》经验,为你挑选了0个好方法。 ...
[详细]
-
如何解决《Nvcc的版本与CUDA不同》经验,为你挑选了0个好方法。 ...
[详细]
-
如何解决《不引人注目的JQuery验证在弹出的PartialViews中不起作用》经验,为你挑选了1个好方法。 ...
[详细]
-
如何解决《无法找到依赖项Microsoft.AspNet.Server.WebListener>=1.0.0-rc1-final》经验,为你挑选了1个好方法。 ...
[详细]
-
如何解决《iOS上的IFrame高度问题(手机游戏)》经验,为你挑选了2个好方法。 ...
[详细]
-
如何解决《Angular2Beta:VisualStudioASP.NETMVC》经验,为你挑选了1个好方法。 ...
[详细]
-
如何解决《通过Android中的深层链接向意图传递额外的值》经验,为你挑选了1个好方法。 ...
[详细]
-
如何解决《如何通过7Zip使用批处理脚本解压缩PASSWORDPROTECTED文件?》经验,为你挑选了1个好方法。 ...
[详细]
-
如何解决《关于使用pandasinplace关键字参数的指南》经验,为你挑选了1个好方法。 ...
[详细]
-
如何解决《Objective-C-如何符合多种协议?》经验,为你挑选了1个好方法。 ...
[详细]
-
如何解决《Python,将mongodump的bson输出转换为json对象数组(字典)》经验,为你挑选了1个好方法。 ...
[详细]
-
如何解决《以编程方式设置UIButton文本颜色》经验,为你挑选了1个好方法。 ...
[详细]
-
如何解决《NumPy中astype的有效参数》经验,为你挑选了1个好方法。 ...
[详细]