MySQL如何查看未提交的事务SQL

MySQL中经常遇到事务中的SQL正在执行或执行完成后未提交,如何找出对应的SQL?

1. 查看正在执行的SQL

查看事务中正在执行的SQL方式有多种,例如

1.1 通过processlist查看

会话1:执行1个SQL

mysql>begin;
QueryOK, 0rowsaffected (0.00sec)


mysql>selectsleep(20),now() ,idfromtest1;

会话2:开启另一个会话,查看对应的SQL

mysql>selectid ,infofrominformation_schema.processlistwhereinfoisnotnull;
+----+------------------------------------------------------------------------------+
|id|info|
+----+------------------------------------------------------------------------------+
|36|selectsleep(20),now() ,idfromtest1|
|37|selectid ,infofrominformation_schema.processlistwhereinfoisnotnull|
+----+------------------------------------------------------------------------------+
2rowsinset (0.00sec)

可以看到正在执行的SQL,包括自己的SQL的id及内容。

1.2 通过events_statements_current查看

会话1:执行1个SQL

mysql>begin;
QueryOK, 0rowsaffected (0.00sec)


mysql>selectsleep(20),now() ,idfromtest1;

会话2:查看对应的SQL

mysql>selecta.id,a.info, b.thread_id, c.sql_textfrominformation_schema.processlista, performance_schema.threadsb, performance_schema.events_statements_currentcwherea.id=b.processlist_idandb.thread_id=c.thread_id\G
***************************1.row***************************
id: 36
info: selectsleep(20),now() ,idfromtest1
thread_id: 76
sql_text: selectsleep(20),now() ,idfromtest1
***************************2.row***************************
id: 37
info: selecta.id,a.info, b.thread_id, c.sql_textfrominformation_schema.processlista, performance_schema.threadsb, performance_schema.events_statements_currentcwherea.id=b.processlist_idandb.thread_id=c.thread_id
thread_id: 77
sql_text: selecta.id,a.info, b.thread_id, c.sql_textfrominformation_schema.processlista, performance_schema.threadsb, performance_schema.events_statements_currentcwherea.id=b.processlist_idandb.thread_id=c.thread_id
2rowsinset (0.01sec)

2. 方式对比

通过processlist和通过events_statements_current区别在于,processlist中能查到的SQL是正在运行的SQL,而运行结束的SQL是看不到的。

会话1:执行1个SQL

mysql>begin;
QueryOK, 0rowsaffected (0.00sec)


mysql>selectsleep(2),now() ,idfromtest1;
+----------+---------------------+----+
|sleep(2) |now() |id|
+----------+---------------------+----+
|0|2023-01-0322:01:09|1|
+----------+---------------------+----+
1rowinset (2.00sec)

此时查看事务情况

mysql>select*frominformation_schema.innodb_trx\G
***************************1.row***************************
trx_id: 421227264232664
trx_state: RUNNING
trx_started: 2023-01-0322:01:09
trx_requested_lock_id: NULL
trx_wait_started: NULL
trx_weight: 0
trx_mysql_thread_id: 36
trx_query: NULL
trx_operation_state: NULL
trx_tables_in_use: 0
trx_tables_locked: 0
trx_lock_structs: 0
trx_lock_memory_bytes: 1128
trx_rows_locked: 0
trx_rows_modified: 0
trx_concurrency_tickets: 0
trx_isolation_level: REPEATABLEREAD
trx_unique_checks: 1
trx_foreign_key_checks: 1
trx_last_foreign_key_error: NULL
trx_adaptive_hash_latched: 0
trx_adaptive_hash_timeout: 0
trx_is_read_only: 0
trx_autocommit_non_locking: 0
trx_schedule_weight: NULL
1rowinset (0.00sec)

其中trx_mysql_thread_id=36的会话正是我们会话1的线程id,但是我们看不到具体的SQL。

mysql>select*frominformation_schema.processlistwhereid=36;
+----+------+-----------+--------+---------+------+-------+------+
|ID|USER|HOST|DB|COMMAND|TIME|STATE|INFO|
+----+------+-----------+--------+---------+------+-------+------+
|36|root|localhost|testdb|Sleep|177||NULL|
+----+------+-----------+--------+---------+------+-------+------+
1rowinset (0.00sec)

但是此时通过方式2就可以查到​

mysql>selecta.id,a.info, b.thread_id, c.sql_textfrominformation_schema.processlista, performance_schema.threadsb, performance_schema.events_statements_currentcwherea.id=b.processlist_idandb.thread_id=c.thread_id\G
***************************1.row***************************
id: 36
info: NULL
thread_id: 76
sql_text: selectsleep(2),now() ,idfromtest1
***************************2.row***************************
id: 37
info: selecta.id,a.info, b.thread_id, c.sql_textfrominformation_schema.processlista, performance_schema.threadsb, performance_schema.events_statements_currentcwherea.id=b.processlist_idandb.thread_id=c.thread_id
thread_id: 77
sql_text: selecta.id,a.info, b.thread_id, c.sql_textfrominformation_schema.processlista, performance_schema.threadsb, performance_schema.events_statements_currentcwherea.id=b.processlist_idandb.thread_id=c.thread_id
2rowsinset (0.00sec)

注意:此时只能查到一个事务中的多条SQL的最后一个。

例如:

mysql>begin;
QueryOK, 0rowsaffected (0.00sec)


mysql>selectsleep(2),now() ,idfromtest1;
+----------+---------------------+----+
|sleep(2) |now() |id|
+----------+---------------------+----+
|0|2023-01-0322:01:09|1|
+----------+---------------------+----+
1rowinset (2.00sec)


mysql>selectsleep(1),now() ,idfromtest1;
+----------+---------------------+----+
|sleep(1) |now() |id|
+----------+---------------------+----+
|0|2023-01-0322:06:35|1|
+----------+---------------------+----+

会话2查看结果

mysql>selecta.id,a.info, b.thread_id, c.sql_textfrominformation_schema.processlista, performance_schema.threadsb, performance_schema.events_statements_currentcwherea.id=b.processlist_idandb.thread_id=c.thread_id\G
***************************1.row***************************
id: 36
info: NULL
thread_id: 76
sql_text: selectsleep(1),now() ,idfromtest1
***************************2.row***************************
id: 37
info: selecta.id,a.info, b.thread_id, c.sql_textfrominformation_schema.processlista, performance_schema.threadsb, performance_schema.events_statements_currentcwherea.id=b.processlist_idandb.thread_id=c.thread_id
thread_id: 77
sql_text: selecta.id,a.info, b.thread_id, c.sql_textfrominformation_schema.processlista, performance_schema.threadsb, performance_schema.events_statements_currentcwherea.id=b.processlist_idandb.thread_id=c.thread_id
2rowsinset (0.00sec)

可见,查到的是最后一个SQL了,如果事务手动commit提交了,则显示的是commit

1. 查看正在执行的SQL

查看事务中正在执行的SQL方式有多种,例如

1.1 通过processlist查看

会话1:执行1个SQL

mysql>begin;
QueryOK, 0rowsaffected (0.00sec)


mysql>selectsleep(20),now() ,idfromtest1;

会话2:开启另一个会话,查看对应的SQL

mysql>selectid ,infofrominformation_schema.processlistwhereinfoisnotnull;
+----+------------------------------------------------------------------------------+
|id|info|
+----+------------------------------------------------------------------------------+
|36|selectsleep(20),now() ,idfromtest1|
|37|selectid ,infofrominformation_schema.processlistwhereinfoisnotnull|
+----+------------------------------------------------------------------------------+
2rowsinset (0.00sec)

可以看到正在执行的SQL,包括自己的SQL的id及内容

1.2 通过events_statements_current查看

会话1:执行1个SQL

mysql>begin;
QueryOK, 0rowsaffected (0.00sec)


mysql>selectsleep(20),now() ,idfromtest1;

会话2:查看对应的SQL

mysql>selecta.id,a.info, b.thread_id, c.sql_textfrominformation_schema.processlista, performance_schema.threadsb, performance_schema.events_statements_currentcwherea.id=b.processlist_idandb.thread_id=c.thread_id\G
***************************1.row***************************
id: 36
info: selectsleep(20),now() ,idfromtest1
thread_id: 76
sql_text: selectsleep(20),now() ,idfromtest1
***************************2.row***************************
id: 37
info: selecta.id,a.info, b.thread_id, c.sql_textfrominformation_schema.processlista, performance_schema.threadsb, performance_schema.events_statements_currentcwherea.id=b.processlist_idandb.thread_id=c.thread_id
thread_id: 77
sql_text: selecta.id,a.info, b.thread_id, c.sql_textfrominformation_schema.processlista, performance_schema.threadsb, performance_schema.events_statements_currentcwherea.id=b.processlist_idandb.thread_id=c.thread_id
2rowsinset (0.01sec)

2. 方式对比

通过processlist和通过events_statements_current区别在于,processlist中能查到的SQL是正在运行的SQL,而运行结束的SQL是看不到的。

会话1:执行1个SQL

mysql>begin;
QueryOK, 0rowsaffected (0.00sec)


mysql>selectsleep(2),now() ,idfromtest1;
+----------+---------------------+----+
|sleep(2) |now() |id|
+----------+---------------------+----+
|0|2023-01-0322:01:09|1|
+----------+---------------------+----+
1rowinset (2.00sec)

此时查看事务情况

mysql>select*frominformation_schema.innodb_trx\G
***************************1.row***************************
trx_id: 421227264232664
trx_state: RUNNING
trx_started: 2023-01-0322:01:09
trx_requested_lock_id: NULL
trx_wait_started: NULL
trx_weight: 0
trx_mysql_thread_id: 36
trx_query: NULL
trx_operation_state: NULL
trx_tables_in_use: 0
trx_tables_locked: 0
trx_lock_structs: 0
trx_lock_memory_bytes: 1128
trx_rows_locked: 0
trx_rows_modified: 0
trx_concurrency_tickets: 0
trx_isolation_level: REPEATABLEREAD
trx_unique_checks: 1
trx_foreign_key_checks: 1
trx_last_foreign_key_error: NULL
trx_adaptive_hash_latched: 0
trx_adaptive_hash_timeout: 0
trx_is_read_only: 0
trx_autocommit_non_locking: 0
trx_schedule_weight: NULL
1rowinset (0.00sec)

其中trx_mysql_thread_id=36的会话正是我们会话1的线程id,但是我们看不到具体的SQL。

mysql>select*frominformation_schema.processlistwhereid=36;
+----+------+-----------+--------+---------+------+-------+------+
|ID|USER|HOST|DB|COMMAND|TIME|STATE|INFO|
+----+------+-----------+--------+---------+------+-------+------+
|36|root|localhost|testdb|Sleep|177||NULL|
+----+------+-----------+--------+---------+------+-------+------+
1rowinset (0.00sec)

但是此时通过方式2就可以查到

mysql>selecta.id,a.info, b.thread_id, c.sql_textfrominformation_schema.processlista, performance_schema.threadsb, performance_schema.events_statements_currentcwherea.id=b.processlist_idandb.thread_id=c.thread_id\G
***************************1.row***************************
id: 36
info: NULL
thread_id: 76
sql_text: selectsleep(2),now() ,idfromtest1
***************************2.row***************************
id: 37
info: selecta.id,a.info, b.thread_id, c.sql_textfrominformation_schema.processlista, performance_schema.threadsb, performance_schema.events_statements_currentcwherea.id=b.processlist_idandb.thread_id=c.thread_id
thread_id: 77
sql_text: selecta.id,a.info, b.thread_id, c.sql_textfrominformation_schema.processlista, performance_schema.threadsb, performance_schema.events_statements_currentcwherea.id=b.processlist_idandb.thread_id=c.thread_id
2rowsinset (0.00sec)

注意:此时只能查到一个事务中的多条SQL的最后一个。

例如:

mysql>begin;
QueryOK, 0rowsaffected (0.00sec)


mysql>selectsleep(2),now() ,idfromtest1;
+----------+---------------------+----+
|sleep(2) |now() |id|
+----------+---------------------+----+
|0|2023-01-0322:01:09|1|
+----------+---------------------+----+
1rowinset (2.00sec)


mysql>selectsleep(1),now() ,idfromtest1;
+----------+---------------------+----+
|sleep(1) |now() |id|
+----------+---------------------+----+
|0|2023-01-0322:06:35|1|
+----------+---------------------+----+

会话2查看结果

mysql>selecta.id,a.info, b.thread_id, c.sql_textfrominformation_schema.processlista, performance_schema.threadsb, performance_schema.events_statements_currentcwherea.id=b.processlist_idandb.thread_id=c.thread_id\G
***************************1.row***************************
id: 36
info: NULL
thread_id: 76
sql_text: selectsleep(1),now() ,idfromtest1
***************************2.row***************************
id: 37
info: selecta.id,a.info, b.thread_id, c.sql_textfrominformation_schema.processlista, performance_schema.threadsb, performance_schema.events_statements_currentcwherea.id=b.processlist_idandb.thread_id=c.thread_id
thread_id: 77
sql_text: selecta.id,a.info, b.thread_id, c.sql_textfrominformation_schema.processlista, performance_schema.threadsb, performance_schema.events_statements_currentcwherea.id=b.processlist_idandb.thread_id=c.thread_id
2rowsinset (0.00sec)

可见,查到的是最后一个SQL了,如果事务手动commit提交了,则显示的是commit。

文章来源网络,作者:管理,如若转载,请注明出处:https://shuyeidc.com/wp/291864.html<

(0)
管理的头像管理
上一篇2025-05-19 21:27
下一篇 2025-05-19 21:28

相关推荐

  • 云服务器和云虚拟主机怎么选?云服务器和虚拟主机区别

    云服务器适合业务增长快、需弹性扩展的场景,而云虚拟主机适合预算有限、技术门槛低的小型静态网站或测试环境,二者核心区别在于资源独享性与运维复杂度,核心差异解析:从底层架构到使用体验很多人容易混淆这两者,觉得它们都是“买空间建站”,它们的底层逻辑完全不同,云服务器(ECS)就像是你租了一整栋别墅,水电网络独立,你想……

    2026-06-29
    0
  • 赣州智慧旅游招聘是真的吗?赣州旅游人才招聘信息

    中级岗位(3-5年经验)月薪范围通常在6000-10000元,这类岗位需要独立负责项目模块,如独立运营一个抖音账号,或维护一个景区小程序的功能迭代,具备成功案例的候选人议价能力较强,高级岗位(5年以上经验)月薪范围通常在10000-20000元,部分核心管理岗可达更高,这类人才需要具备战略规划能力,如制定整个景……

    2026-06-29
    0
  • 赣州智能物联网车位锁如何管理?智能车位锁管理系统多少钱

    赣州智能物联网车位锁管理的核心在于通过云端平台实现远程控锁、状态实时监控及自动计费,彻底解决传统车位“被占难管”与“找位难”的痛点,在赣州这样的城市,随着机动车保有量的持续增长,老旧小区、商业综合体以及私人固定车位的资源矛盾日益凸显,传统的机械地锁或简易遥控锁,不仅操作繁琐,更无法实现数据化管理,引入智能物联网……

    2026-06-29
    0
  • 赣州智能消防栓好用吗,智能消防栓多少钱一个

    赣州智能消防栓通过物联网技术实现实时监测与远程报警,能显著降低火灾响应时间并提升城市消防安全管理水平,是目前智慧城市建设中不可或缺的基础设施,赣州智能消防栓的核心价值与应用场景传统消防栓往往存在“看不见、摸不着、用不了”的痛点,在赣州这样地形复杂、老城区与新城区并存的区域,传统设施的管理难度极大,智能消防栓的出……

    2026-06-29
    0
  • 云服务器和物理机到底有啥区别?

    云服务器本质上是虚拟化资源池中的弹性实例,而传统物理服务器是独占的硬件实体,前者胜在弹性与运维便捷,后者强在物理隔离与性能稳定,具体选择取决于业务对成本、扩展性及安全合规的权衡,很多人初次接触服务器时,容易把“云服务器”和“传统物理服务器”混为一谈,觉得它们都是用来跑网站或存数据的盒子,这两者的底层逻辑完全不同……

    2026-06-29
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注