为了账号安全,请及时绑定邮箱和手机立即绑定

MySQL优化之如何了解SQL的执行频率

标签:
MySQL

 show [session|global] status 可以根据需要加上参数“ session ”或者“ global ”来显示 session 级(当前连接)的统计结果和 global 级(自数据库上次启动至今)的统计结果。如果不写,默认使用参数是“ session ”。

    Com_xxx 表示每个 xxx 语句执行的次数,我们通常比较关心的是以下几个统计参数 :

•Com_select :执行 select 操作的次数,一次查询只累加 1 。
•Com_insert :执行 INSERT 操作的次数,对于批量插入的 INSERT 操作,只累加一次。
•Com_update :执行 UPDATE 操作的次数。
•Com_delete :执行 DELETE 操作的次数。

    知道了这些信息就方便我们确定我们到底需要什么样的存储引擎了,一般来说update较多的时候 Innodb 引擎效率会稍微高一些!

    上面这些参数对于所有存储引擎的表操作都会进行累计。下面这几个参数只是针对 InnoDB 存储引擎的,累 加的算法也略有不同:

•Innodb_rows_read : select 查询返回的行数。
•Innodb_rows_inserted :执行 INSERT 操作插入的行数。
•Innodb_rows_updated :执行 UPDATE 操作更新的行数。
•Innodb_rows_deleted :执行 DELETE 操作删除的行数。

    通过以上几个参数,可以很容易地了解当前数据库的应用是以插入更新为主还是以查询操作为主,以及各种类型的 SQL 大致的执行比例是多少。对于更新操作的计数,是对执行次数的计数,不论提交还是回滚都会进行累加。
    对于事务型的应用,通过 Com_commit 和 Com_rollback 可 以了解事务提交和回滚的情况,对于回滚操作非常频繁的数据库,可能意味着应用编写存在问题。
    此外,以下几个参数便于我们了解数据库的基本情况:

•Connections : 试图连接 MySQL 服务器的次数。
•Uptime :服务器工作时间。
•Slow_queries : 慢查询的次数。


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消