Mysql查询正在执行的事务以及等待锁的操作方式
发表于:2025-02-03 作者:千家信息网编辑
千家信息网最后更新 2025年02月03日,使用navicat测试学习:首先使用set autocommit = 0;(取消自动提交,则当执行语句commit或者rollback执行提交事务或者回滚)在打开一个执行update查询 正在执行的事
千家信息网最后更新 2025年02月03日Mysql查询正在执行的事务以及等待锁的操作方式
使用navicat
测试学习:
首先使用set autocommit = 0;
(取消自动提交,则当执行语句commit或者rollback执行提交事务或者回滚)
在打开一个执行update
查询 正在执行的事务:
SELECT * FROM information_schema.INNODB_TRX
根据这个事务的线程ID(trx_mysql_thread_id
):
从上图看出对应的mysql
线程:一个94362 (第二个正在等待锁)另一个是93847(第一个update 正在执行 没有提交事务)
可以使用mysql命令:kill
线程id 杀掉线程
期间如果并未杀掉持有锁的线程:则第二个update语句提示等待锁超时
查询mysql数据库中还可以使用:
查看正在锁的事务
SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCKS;
查看等待锁的事务
SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCK_WAITS;
查询mysql数据库中存在的进程
[sql] view plain copy
select * from information_schema.`PROCESSLIST`(show processlist;)
概念:
mysql中database
、instance
、session
。
mysql中建立一个会话,不是和具体的数据库相连接,而是跟instance建立会话(即在navicat上执行一个查询,可以查询端口下对应的多个数据库,查询时数据库名+数据表名即可)
在一个物理机上可以建立多个instance
,通过port
来区分实例。
而一个实例可以建立多个数据库,即一个会话可以操作一个实例上的多个数据库。
jdbc协议连接数据库:jdbc:mysql://localhost:3306/test
jdbc协议连接本地上端口为3306实例下的test数据库,则查询数据表时不需要加上数据库的名字。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。如果你想了解更多相关内容请查看下面相关链接
数据
数据库
查询
事务
线程
正在
多个
实例
内容
学习
数据表
端口
语句
上图
价值
名字
命令
就是
更多
概念
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
厦门天齐网络技术有限公司
163怎么设置邮件服务器
检测服务器安全工具
域服务器 2012
计算机软件开发可以做什么
网络安全管理法律法规汇编
三丰云免费服务器
DNF手游用什么软件开发
win8 媒体服务器
数据库安装服务名是什么软件
国内哪里买移动服务器便宜
我是网络安全小卫士标题图片
数据库更新为空
小学微信网络安全管理办法
技校学的计算机网络技术
触动网络技术
数据库怎么存储博客的内容
网络安全防传销
邯郸厚昌网络技术有限公司
专科计算机网络技术前景
数据库中的小数点怎么弄
阿里巴巴网络安全技术总监是谁
网络安全靠人民三年级手抄报
淘车网络技术
东城服务器搬迁收费标准
器 美国vps云服务器 网站群
定制数据库引擎
互联网与科技进步
云图网络技术支持 保定
软件开发管理追溯的必要性