首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

mysql 查看执行过的语句

基础概念

MySQL查看执行过的语句通常是指查看MySQL服务器上的查询日志或慢查询日志。这些日志记录了数据库服务器上执行的SQL语句,包括查询、插入、更新和删除操作。

相关优势

  1. 调试和优化:通过查看执行过的SQL语句,可以分析和优化查询性能。
  2. 审计和安全:日志可以帮助审计数据库活动,检测潜在的安全问题。
  3. 故障排除:当数据库出现问题时,日志可以提供关键信息来诊断问题。

类型

  1. 通用查询日志(General Query Log):记录所有客户端连接和执行的SQL语句。
  2. 慢查询日志(Slow Query Log):记录执行时间超过设定阈值的SQL语句。
  3. 二进制日志(Binary Log):记录所有更改数据的SQL语句的格式化事件,用于复制和恢复。

应用场景

  • 性能调优:通过分析慢查询日志,找出执行缓慢的SQL语句并进行优化。
  • 安全审计:监控和记录数据库活动,确保数据安全。
  • 故障恢复:在数据库故障时,通过日志恢复数据。

如何查看执行过的SQL语句

查看通用查询日志

通用查询日志通常不推荐在生产环境中使用,因为它会记录大量的信息,影响性能。

代码语言:txt
复制
-- 查看通用查询日志是否开启
SHOW VARIABLES LIKE 'general_log';

-- 开启通用查询日志
SET GLOBAL general_log = 'ON';

-- 查看通用查询日志文件位置
SHOW VARIABLES LIKE 'general_log_file';

查看慢查询日志

慢查询日志记录执行时间超过设定阈值的SQL语句。

代码语言:txt
复制
-- 查看慢查询日志是否开启
SHOW VARIABLES LIKE 'slow_query_log';

-- 开启慢查询日志
SET GLOBAL slow_query_log = 'ON';

-- 设置慢查询阈值(单位:秒)
SET GLOBAL long_query_time = 2;

-- 查看慢查询日志文件位置
SHOW VARIABLES LIKE 'slow_query_log_file';

查看二进制日志

二进制日志记录所有更改数据的SQL语句的格式化事件。

代码语言:txt
复制
-- 查看二进制日志是否开启
SHOW VARIABLES LIKE 'log_bin';

-- 查看二进制日志文件位置
SHOW VARIABLES LIKE 'log_bin_basename';

遇到的问题及解决方法

问题:日志文件过大

原因:日志文件过大可能导致磁盘空间不足。

解决方法

  1. 定期清理日志文件
  2. 定期清理日志文件
  3. 设置日志轮转
  4. 设置日志轮转

问题:日志记录过多影响性能

原因:通用查询日志记录所有SQL语句,可能导致性能下降。

解决方法

  1. 关闭通用查询日志
  2. 关闭通用查询日志
  3. 优化慢查询日志阈值
  4. 优化慢查询日志阈值

参考链接

通过以上方法,你可以有效地查看和分析MySQL执行过的SQL语句,从而进行性能优化和安全审计。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

mysql查看执行过的历史sql语句

B端,2)B端订单需要同步到一套ERP系统;3)订单管理、财务结算、物流配置需要全部在erp中实现;为了提交开发效率,打算用最传统的方法:通过在被同步端按人工录入一次数据,记录一次执行sql语句,即方便...查看mysql日志状态,日志路径show variables like 'general_log%'开启日志记录:set GLOBAL general_log=on关闭日志记录set GLOBAL general_log...=off本人开发环境是5.7,其它版本暂未测试,是否有效请自行测试,详情可以参考mysql官网有关“通用查询日志”https://dev.mysql.com/doc/refman/8.0/en/query-log.html...英文不好的同事可以百度或者使用chrome自带翻译,查看更方便。...早年某培训机构推荐过一个php版本的日志查看工具,因换电脑忘记名称,有知道的欢迎推荐给我,谢谢!

12110
  • MySQL查看实时执行的SQL语句

    MySQL默认不能实时查看执行的SQL语句,因为这会消耗一定的资源。 要开启这个功能,稍微配置一下,打开这个LOG记录就可以了。 1 查看LOG功能 首先,查看是否已经开启实时SQL语句记录。...,并指定自定义的log路径: mysql> SET GLOBAL general_log = 'ON'; mysql> SET GLOBAL general_log_file = '/var/log/...说明:这个文件会随着访问的增加而不断变大,所以生产环境建议临时开启,用完及时关闭。...3 实时查看 过一小段时间后,就可以导出查看/var/lib/mysql/sql_statement.log文件了,里面记录了所有执行的SQL语句。...如果要实时查看该文件的改动,在Linux系统用tail命令: $ tail -f /var/lib/mysql/general_sql.log 另外,也可以用BareTail软件实时查看。

    5.1K20

    MySQL性能优化-查看执行慢的SQL语句

    MySQL性能优化-查看执行慢的SQL语句 查看执行慢的SQL语句,需要先开启慢查询日志 默认情况下,MySQL数据库没有开启慢查询日志 慢日志常用配置项 #是否启用慢查询日志 slow_query_log...= ON #指定慢查询日志文件位置及名称 slow_query_log_file = /var/lib/mysql/my-slow.log #慢查询执行时间阈值,超过此时间会记录,默认为10,单位为s...查看是否开启慢查询日志 show variables like '%slow_query_log%'; 查看慢查询日志存放文件位置 show variables like '%slow_query_log...%'; 查看long_query_time阈值 show variables like '%long_query_time%'; 修改配置文件配置慢日志 #使用vi编辑器编辑mysql配置信息 vi /.../my-slow.log #慢查询执行时间阈值,超过此时间会记录,默认为10,单位为s long_query_time = 10 #日志文件中的显示时区 log_timestamps = SYSTEM

    15310

    MySQL使用技巧: 如何查看mysql正在执行的SQL语句

    MySQL使用技巧: 如何查看mysql正在执行的SQL语句 背景: 最近项目开发用到MySQL,想要查看后台执行的sql语句,立马google得知、可以使用 show processlist; 命令来解决...,通过里面输出结果的字段解释中可以分析执行了的sql语句类型,但发现不太适合一般的初级使用者,而通过日志文件查看sql语句是最直接的方法。.../log.txt1    log=d:/mysql/data/log.txt 3:如此就可以记录所有的mysql执行的sql语句!  ...state列,显示使用当前连接的sql语句的状态,很重要的列,后续会有所有的状态的描述,请注意,state只是语句执行中的某一个状态,  一个sql语句,已查询为例,可能需要经过copying to tmp...MySQL会在每次的主循环中检查kill标志位,不过有些情况下该线程可能会过一小段才能死掉。如果该线程程被其他线程锁住了,那么kill请求会在锁释放时马上生效。

    8.1K20

    MySQL的语句执行顺序

    MySQL的语句一共分为11步,如下图所标注的那样,最先执行的总是 FROM操作,最后执行的是LIMIT操作。...其中每一个操作都会产生一张虚拟的表,这个虚拟的表作为一个处理的输入,只是这些虚拟的表对用户来说是透明 的,但是只有最后一个虚拟的表才会被作为结果返回。...如果没有在语句中指定某一个子句,那么将会跳过相应的步骤。 ? 下面我们来具体分析一下查询处理的每一个阶段 FORM: 对FROM的左边的表和右边的表计算笛卡尔积。...,那么就会对上一个join连接产生的结果VT3和下一个表重复执行步骤1~3这三个步骤,一直到处理完所有的表为 止。...SELECT: 执行select操作,选择指定的列,插入到虚拟表VT8中。 DISTINCT: 对VT8中的记录进行去重。产生虚拟表VT9.

    6.5K100

    Mysql语句的执行过程

    当你希望MySQL能够以更高的性能运行查询时,最好的办法是弄清楚MySQL是如何优化和执行查询。...《高性能MySQL》 衡量查询开销的三个指标 响应时间扫描的行数 服务时间(处理这条语句真正花的时间) 排队时间(等待资源,例如IO,行锁等) 扫描的行数 返回的行数 当删除了搜索条件列的索引时,语句进行全表扫描...查询优化处理(解析SQL、预处理、优化SQL的执行计划),将SQL转化成一个执行计划。 解析和预处理:生成一棵解析树(《编译原理》的知识),MySQL按照其语法对解析树进行验证和解析查询。...优化过程书上介绍了很多情况,请参考书籍6.43章 执行计划 MySQL会生成一个指令树,然后通过存储引擎完成这棵树并返回结果 如图2 查询执行引擎  查询执行引擎则根据执行计划来完成整个查询。...在执行计划时,存储引擎通过调用实现的接口来完成。 ?  图三 四个表的表连接查询的执行计划指令树 3.返回结果 如果查询可以被缓存,MySQL将结果存放到查询缓存里。

    2.6K20

    MySQL执行sql语句的机制

    目录 1 概念 2 执行过程 1 概念 连接器: 身份认证和权限相关(登录 MySQL 的时候)。...查询缓存: 执行查询语句的时候,会先查询缓存(MySQL 8.0 版本后移除,因为这个功能不太实用)。...第二步,语法分析,主要就是判断你输入的 sql 是否正确,是否符合 MySQL 的语法。 优化器: 按照 MySQL 认为最优的方案去执行。 执行器: 执行语句,然后从存储引擎返回数据。...2 执行过程 查询语句的执行: 1、鉴权 2、查询缓存 3、分析sql,提取关键字select 、表名、列字段、查询条件,然后判断语法 4、优化执行方案,自己的优化算法不一定是最优 5、再次权限校验...,然后调用数据库引擎,返回执行结果 更新(包括删除、新增)语句的执行: 执行更新语句时会就日志:归档日志和重做日志, 1、先查询数据 2、然后将查出的数据修改,调用引擎API接口写入这一行数据,InnoDB

    3.8K30
    领券