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

2017-01-13 10:48:23来源:网络收集作者:三线码农人点击

1、查询是否锁表


show OPEN TABLES where In_use > 0;

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


查看正在锁的事务


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 thenleave label;
elseselect i ;
end if ;
end

最新文章

123

最新摄影

微信扫一扫

第七城市微信公众平台