搜索
 找回密码
 立即注册
发新帖

mariadb教程[76] 改善性能

时间:2020-3-24 16:38 0 610 | 复制链接 |

610

主题

610

帖子

0

积分

网站编辑

Rank: 8Rank: 8

积分
0
1.mariadb是用一系列的默认设置预先配置的,从这些设置开始通常是很好的。但过一段时间后你可能需要调整内存分配、缓冲区大小等。(为查看当前设置,可使用show variables;和show status;)
2.mariadb是一个多用户多线程的dbms,换言之,它经常同时执行多个任务。如果这些任务中的某一个执行缓慢,则所有请求都会执行缓慢。如果你遇到显著的性能不良,可使用show processlist显示所有活动进程(以及它们的线程id和执行时间)。你还可以用kill命令终结某个特定的进程(使用这个命令需要作为管理员登录)。
3.总是有不止一种方法编写同一条select语句,应该试验联结、并、子查询等,找出最佳的方法。
4.使用explain语句让mariadb解释它将如何执行一条select语句。
5.一般来说,存储过程执行得比一条一条地执行其中的各条mariadb语句快。
6.应该总是使用正确的数据类型。
7.决不要检索比需求还要多的数据。换言之,不要用select *(除非你真正需要每个列)。
8.有的操作(包括insert)支持一个可选的delayed关键字,如果使用它,将把控制立即返回给调用程序,并且一旦有可能就实际执行该操作。
9.在导入数据时,应该关闭自动提交。你可能还想删除索引(包括fulltext索引),然后在导入完成后再重建他们。
10.必须索引数据库表以改善数据检索的性能。确定索引什么不是一件微不足道的任务,需要分析使用的select语句以找到重复的where和order by子句。如果一个简单的where子句返回结果所花的时间太长,则可以断定其中使用的列(或几个列)就是需要索引的对象。
11.你的select语句中有一系列复杂的or条件吗?通过使用多条select语句和连接它们的union语句,你能看到极大的性能改进。
12.索引改善数据检索的性能,但损害数据插入、删除和更新的性能。如果你有一些表,它们收集数据且不经常被搜索,则在有必要之前不要索引它们。(索引可根据需要添加和删除)。
13.like很慢。一般来说,最好是使用fulltext而不是like。

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

快速回复 返回列表 返回顶部