转自:http://www.cnblogs.com/william-lin/archive/2013/03/19/2968727.html
--存储过程名和参数,参数中in表示传入参数,out标示传出参数,inout表示传入传出参数 create procedure p_procedurecode(in sumdate varchar(10))
begin
declare v_sql varchar(500); --需要执行的SQL语句
declare sym varchar(6); declare var1 varchar(20);
declare var2 varchar(70);
declare var3 integer; --定义游标遍历时,作为判断是否遍历完全部记录的标记
declare no_more_departments integer DEFAULT 0; --定义游标名字为C_RESULT
DECLARE C_RESULT CURSOR FOR
SELECT barcode,barname,barnum FROM tmp_table; --声明当游标遍历完全部记录后将标志变量置成某个值
DECLARE CONTINUE HANDLER FOR NOT FOUND
SET no_more_departments=1; set sym=substring(sumdate,1,6); --截取字符串,并将其赋值给一个遍历 --连接字符串构成完整SQL语句,动态SQL执行后的结果记录集,在MySQL中无法获取,因此需要转变思路将其放置到一个临时表中(注意代码中的写法)。一般写法如下: -- 'Create TEMPORARY Table 表名(Select的查询语句);
set v_sql= concat('Create TEMPORARY Table tmp_table(select aa as aacode,bb as aaname,count(cc) as ccnum from h',sym,' where substring(dd,1,8)=''',sumdate,''' group by aa,bb)'); set @v_sql=v_sql; --注意很重要,将连成成的字符串赋值给一个变量(可以之前没有定义,但要以@开头)
prepare stmt from @v_sql; --预处理需要执行的动态SQL,其中stmt是一个变量
EXECUTE stmt; --执行SQL语句
deallocate prepare stmt; --释放掉预处理段 OPEN C_RESULT; --打开之前定义的游标
REPEAT --循环语句的关键词
FETCH C_RESULT INTO VAR1, VAR2, VAR3; --取出每条记录并赋值给相关变量,注意顺序 --执行查询语句,并将获得的值付给一个变量 @oldaacode(注意如果以@开头的变量可以不用通过declare语句事先声明)
select @oldaacode:=vcaaCode from T_sum where vcaaCode=var1 and dtDate=sumdate;
if @oldaacode=var1 then --判断
update T_sum set iNum=var3 where vcaaCode=var1 and dtDate=sumdate;
else
insert into T_sum(vcaaCode,vcaaName,iNum,dtDate) values(var1,var2,var3,sumdate);
end if;
UNTIL no_more_departments END REPEAT; --循环语句结束
CLOSE C_RESULT; --关闭游标 DROP TEMPORARY TABLE tmp_table; --删除临时表
end;

最新文章

  1. mysql: unknown variable 'character-set-client=utf8'
  2. 转:不再以讹传讹,GET和POST的真正区别
  3. andorid 远程存储中JDK和Volley的GET和POST方法
  4. python 异常含义
  5. 回调函数与DOM事件
  6. 【HDOJ】1695 GCD
  7. EF code first 生成edmx文件
  8. MYSQL数据备份与还原学习笔记
  9. JS多选日期
  10. 【linux驱动】linux驱动总览
  11. Hibernate入门(五)
  12. 使用REST风格架构您需要知道的一些事
  13. arcgis api 3.x for js 实现克里金插值渲染图不依赖 GP 服务(附源码下载)
  14. vue引入fastclick设置输入框type="number"报错Failed to execute 'setSelectionRange' on 'HTMLInputElement': The input element's type ('number') does not support selection.的解决办法
  15. 关于HTMl CSS
  16. Java爬虫框架Jsoup学习记录
  17. SpringBoot-@RequestParam
  18. python 的包的导入
  19. Docker两种方式进入后台运行的容器
  20. JS获取本周、本季度、本月、上月的开始日期、结束日期

热门文章

  1. 2018-2-13-win10-UWP-应用设置
  2. Linux操作练习
  3. const char *转化为char *的方法
  4. react 编写 基于ant.design 页面的参考笔记
  5. centos7 iperf3安装
  6. shell--grep命令+正则表达式+基本语法
  7. BlueStore-先进的用户态文件系统《二》-BlueFS
  8. bzoj 3011
  9. spring boot2.x集成spring security5与druid1.1.13(一)
  10. html生成pdf