mysql查看锁住的表和事务隔离级别及存储过程跳出循环处理方式

本文介绍了MySQL中如何查询锁定的表和进程、查看正在锁的事务及等待锁的事务等操作。同时详细解释了四种不同的隔离级别:read uncommitted、read committed、repeatable read 和 serializable 的含义及其在MySQL中的应用。
摘要由CSDN通过智能技术生成

1、查询是否锁表

show OPEN TABLES where In_use > 0;

2、查询进程
show processlist
查询到相对应的进程,然后 kill id



查看正在锁的事务

SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCKS; 

查看等待锁的事务

SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCK_WAITS; 

另外:
mysql隔离级别:

1.查看当前会话隔离级别

select @@tx_isolation;

2.查看系统当前隔离级别

select @@global.tx_isolation;

3.设置当前会话隔离级别

set session transaction isolatin level repeatable read;

4.设置系统当前隔离级别

set global transaction isolation level repeatable read;

5.命令行,开始事务时

set autocommit=off 或者 start transaction

关于隔离级别的理解

1.read uncommitted

可以看到未提交的数据(脏读),举个例子:别人说的话你都相信了,但是可能他只是说说,并不实际做。

2.read committed

读取提交的数据。但是,可能多次读取的数据结果不一致(不可重复读,幻读)。用读写的观点就是:读取的行数据,可以写。

3.repeatable read(MySQL默认隔离级别)

可以重复读取,但有幻读。读写观点:读取的数据行不可写,但是可以往表中新增数据。在MySQL中,其他事务新增的数据,看不到,不会产生幻读。采用多版本并发控制(MVCC)机制解决幻读问题。

4.serializable

可读,不可写。像java中的锁,写数据必须等待另一个事务结束。

mysql存储过程中跳出循环:

CREATE DEFINER=`root`@`%` PROCEDURE `test`(p INT)
BEGIN
  label: LOOP
    SET p = p + 1;
    IF p <= 10 THEN 
     select 'repeate';
     ITERATE label; 
    END IF;
    select 'skip';
    LEAVE label; 
  END LOOP label;
  SET @x = p;
  select @x;  
END

mysql存储过程跳出整个过程:

CREATE DEFINER=`root`@`localhost` PROCEDURE b (p int) 
label:begin 
declare i int ; 
set i=p; 
if i<1 then  leave label; 
else  select i ;
 end if ; 
end
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值