zoukankan      html  css  js  c++  java
  • 数据库调优教程(三)记录慢查询

    一、           发现慢查询


    上一讲我们为慢查询的发生做了数据准备,这一讲就让我们来发现慢查询,同时把它记录到文件中

    3.      记录慢查询


    此时我们已经有让慢查询发生的成本了。执行以下语句,你就知道什么叫慢!查!询!

    select empno from emp where ename='';


    一个很明显找不到结果的查询语句居然也执行了近3秒钟。

    这时候,作为DBA就应该把这个sql语句记录下来,是记在记事本还是写在笔记本呢?不用想太多了,不用你自己记,Mysql提供了慢查询日志功能,自动帮你记录慢查询的语句。

    1)    把慢查询的sql记录到日志中

    首先你要打开慢查询日志文件记录器

    使用

    show variables like 'slow%';

    你会发现默认情况下慢查询日志记录器关闭的

    使用

    set global slow_query_log=ON;

    打开之



    此时你会发现mysql安装目录下的data文件夹中出现了以你本机名命名的日志文件


    此时再执行慢查询操作


    打开日志文件发现出现记录


    以后只需要定期检查日志文件就可以找到慢查询语句了


    注意:

    在找到慢查询语句后,要通过反复使用select语句确认慢查询,注意只能使用select语句,就算是原来语句为delete或者update等,也要用select代替,因为只有select不会弄脏数据库


    2)    另一种发现慢查询语句的方法

    要是你使用Hibernate进行J2ee开发,可以使用一下方式。

    在页面中进行操作,当发现某个操作的响应较慢时,查看Eclipse控制台的Hibernate输出sql语句,此语句即为慢查询语句。


    本章结束,下一章我们将讲解如何使用mysql的性能分析命令Explain。
  • 相关阅读:
    windows用户管理与远程管理
    Linux之基础网络配置
    linux之程序包管理
    linux之特殊权限
    设计模式学习笔记——Prototype原型模式
    设计模式学习笔记——Visitor 访问者模式
    XXX is not a function
    终于决定要开始写自己的博客了,先Mark一下
    element ui 与vue跨域通信操作 和框架语法,contentype
    跨域与版本控制
  • 原文地址:https://www.cnblogs.com/javdroider/p/5184316.html
Copyright © 2011-2022 走看看