变量分类
会话变量
SET @var1 = 1;
作用域:仅限于当前连接。当当前连接断开后,其设置的所有会话变量均失效。
局部变量
DECLARE a INT DEFAULT 0;
作用域:仅限于该begin/end语句块内,在该语句块执行完毕后,局部变量就消失了。
游标的作用
遍历SELECT出来的数据集
游标的用法
DECLARE isend int DEFAULT 0;
DECLARE pid int;
DECLARE num int;
DECLARE cur CURSOR FOR select pid,sum(clicknum) from user; #定义游标
DECLARE CONTINUE HANDLER FOR NOT FOUND SET isend = 1; #游标结束时设为1
open cur;
fetch cur into pid,num;
WHILE isend!=1 do
UPDATE user SET click_num=num WHERE prod_id=pid;
fetch cur into pid,num;
END WHILE;
close cur;
事务(只有InnoDB支持)
事务作用:控制操作集合,如果都成功就提交,如果有某天操作不成功就回滚
事务语法:
1、手动开启事务:START TRANSACTION;
2、提交:COMMIT;
3、回滚:ROLLBACK;
事务案例:
DECLARE err int DEFAULT 0;
DECLARE CONTINUE HANDLER FOR SQLEXCEPTION SET err = 1; #出错时,游标设为1
START TRANSACTION;
#写SQL操作语句(增删改)#
IF err=1 THEN
ROLLBACK;
ELSE
COMMIT;
END IF;
表锁和行锁
表锁(InnoDB和MyISAM都支持)
LOCK TABLE xxx READ;(读锁)
LOCK TABLE xxx WRITE;(写锁)
UNLOCK TABLES; 解锁
行锁(InnoDB支持)