一个游标引发的血案,哈哈
来源:互联网 发布:java中的类 编辑:程序博客网 时间:2024/06/05 12:40
还是要严谨些,害人害己
begin
DECLARE myid int;
DECLARE notfound INT DEFAULT 0; #定义一个辅助变量用于判断
DECLARE mycursor CURSOR FOR SELECT DISTINCT c.userid FROM hde.chio c LEFT JOIN DB_USER.User_TAB u on c.userid = u.userID where DATE_FORMAT(FROM_UNIXTIME(c.addtimestamp/1000),'%Y-%m-%d') = DATE_FORMAT(_date,'%Y-%m-%d') and c.userid > 0 ; #把select出来的数据全部保存到游标mycursor中
DECLARE CONTINUE HANDLER FOR NOT FOUND SET notfound = 1; #定义declare continue handler, 必须在游标定义后定义
OPEN mycursor; #打开游标
REPEAT
fetch mycursor into myid; #读取游标中的数据一一复给变量myid。
CALL admin_user_staticstic_procedure(myid,DATE_FORMAT(_date,'%Y-%m-%d'));
UNTIL notfound END REPEAT;#判断是不是到了最后一条数据
close mycursor;#最后关闭游标.游标里面存放了那么多数据总是要清理掉的吧。
end
begin
DECLARE myid int;
DECLARE notfound INT DEFAULT 0; #定义一个辅助变量用于判断
DECLARE mycursor CURSOR FOR SELECT DISTINCT c.userid FROM hde.chio c LEFT JOIN DB_USER.User_TAB u on c.userid = u.userID where DATE_FORMAT(FROM_UNIXTIME(c.addtimestamp/1000),'%Y-%m-%d') = DATE_FORMAT(_date,'%Y-%m-%d') and c.userid > 0 ; #把select出来的数据全部保存到游标mycursor中
DECLARE CONTINUE HANDLER FOR NOT FOUND SET notfound = 1; #定义declare continue handler, 必须在游标定义后定义
OPEN mycursor; #打开游标
REPEAT
fetch mycursor into myid; #读取游标中的数据一一复给变量myid。
CALL admin_user_staticstic_procedure(myid,DATE_FORMAT(_date,'%Y-%m-%d'));
UNTIL notfound END REPEAT;#判断是不是到了最后一条数据
close mycursor;#最后关闭游标.游标里面存放了那么多数据总是要清理掉的吧。
end
其实是一个意思;注意循环退出条件和游标结果集非空处理,不然会抛异常:Procedure execution failed 1329 - No data - zero rows fetched, selected, or processed.....
切记切记
修改存储过程定义者:
update mysql.proc set DEFINER='usename' WHERE NAME='proc_name' AND db='mydb';
0 0
- 一个游标引发的血案,哈哈
- 一个 * 引发的血案
- 一个“-”引发的血案
- 一个"/"引发的血案
- 一个松果引发的血案
- 一个memset引发的血案
- 一个包子引发的血案?
- 一个斜杠引发的血案
- 一个逗号引发的"血案"
- 一个static 引发的“血案”
- 一个分号引发的血案
- 一个key引发的血案
- 一个变量引发的血案
- 一个return引发的血案
- 一个ViewSwitcher引发的血案!
- 一个分号引发的“血案”
- 一个static引发的血案
- 一个2803引发的血案
- Java接口分页模版
- C语言 实现一个双链表
- 对象的集合 -- 栈,使用stl 中的vector 或者 原始数组来实现
- 使用StringBuilder构建字符串
- 集群时的缓存同步
- 一个游标引发的血案,哈哈
- 在没有备份的情况下通过rowid提取数据文件损坏的表空间中的部分数据
- Java并发编程规则:不可变对象永远是线程安全的
- gradle 打生产开发两种包
- Android之View与viewGroup的区别
- QT开发之QProcess进程运行外部程序
- Spring 限制用户重复登录
- 索引算法原理解析(B-tree以及磁盘存储原理)
- Rxjava + Retrofit 错误拦截