返回首页

mysql 存储过程

时间:2012-07-16 00:29来源:知行网www.zhixing123.cn 编辑:麦田守望者

今天要做一个统计报表,想到使用存储过程来做。
mysql的存储过程以前没有用过,这次想试试,在编写的过程中遇到了不少问题:
首先,看了官方的文档 ,不过对于存储过程,还是要使用才知道。文档是死的,人是活的。

1.怎么创建存储过程,自然也是使用一定语法,然后运行,如果成功,会有一个对应的文

件产生,并可以通过 call 来调用。

2.设定变量要注意,不是全局变量(@)时,要先定义(DECLARE year_months VARCHAR(10))

3.设置变量时的语法,在变量前面加 SET 关键字,不然报错

4.直接执行SQL,是可以的,但是如果我们的SQL是动态的,比如我们表名是通过参数传进来的。

这时间要另外一种方式了,要将sql,使用CONCAT(,,,),来讲sql连接起来。还有就是字符串拼接时,

最好使用CONCAT(见下面的)函数,不然会有问题。

下面是我写的一个实例:

DROP PROCEDURE IF EXISTS `crm_sms_stat`;

CREATE DEFINER=`boss`@`%` PROCEDURE `crm_sms_stat`(IN years varchar(10),IN m varchar(10),IN last_months varchar(10))
BEGIN
DECLARE year_months VARCHAR(10);
DECLARE year_m VARCHAR(10);
DECLARE mt_sms_yearmonth VARCHAR(20);
DECLARE r_year_month VARCHAR(20);
DECLARE last_r_year_month VARCHAR(20);


SET year_months = CONCAT(years,m);
SET year_m = CONCAT(years,'-',m);
SET mt_sms_yearmonth = CONCAT("mt_sms_",year_months);
SET r_year_month = CONCAT(years,"_",m);

IF m = "01" THEN
SET years = years - 1;
SET last_months = "12";
END IF;
SET last_r_year_month = CONCAT(years,"_",last_months);

IF years = "2008" THEN
SET r_year_month = CONCAT("R",r_year_month);
SET last_r_year_month = CONCAT("R",last_r_year_month);
END IF;


/*---------------------------------------------------------------- */
SET @insertStat = CONCAT(' INSERT INTO crm_sms_stat(months,user_id,username,agentid) ',
' select "',year_months,'",u.user_id,u.username,u.agentid from ',mt_sms_yearmonth,
' mt inner join users u on mt.user_id=u.user_id group by mt.user_id ');
PREPARE insertS FROM @insertStat;
EXECUTE insertS;


SET @tempupdateRemain = CONCAT(' UPDATE crm_monthRemain cm,crm_sms_stat css SET css.last_remain = ifnull(',
last_r_year_month,',0),css.this_remain = ifnull(', r_year_month,',0) ',
' WHERE cm.id = css.user_id and css.months = "',year_months,'" ');
PREPARE remain FROM @tempupdateRemain;
EXECUTE remain;

-- 更新每个月用户所冲条数
SET @tempadd = CONCAT(' UPDATE crm_sms_stat css inner join (select name,sum(total_count) addNum from boss_addmoney ',
' where left(add_date,7)= "',year_m,'" and total_count >=0 and name not like "%=%" and name not like "%:%" group by name) ',
' x on css.username= x.name and css.months = "',year_months ,'" ',
' SET css.add_num = ifnull(x.addNum,0) ');
PREPARE addnum FROM @tempadd;
EXECUTE addnum;




IF years = "08" THEN
-- 更新通道发送数(200901之前是不分卡发和通道的)
SET @tempChannel08 = CONCAT('UPDATE crm_sms_stat css inner join (select mt.user_id,',
' sum(length(replace(mt.dest_mobile,";","")))/11 chennel_num',
' from ',mt_sms_yearmonth,' mt ',
' group by mt.user_id) x on css.user_id = x.user_id and css.months = "',year_months,'"',
' set css.channel_num = ifnull(x.chennel_num,0) ');

PREPARE channel08 FROM @tempChannel08;
EXECUTE channel08;
ELSE
-- channel send number
SET @tempChannel = CONCAT('UPDATE crm_sms_stat css inner join (select mt.user_id,',
' sum(length(replace(mt.dest_mobile,";","")))/11 chennel_num',
' from ',mt_sms_yearmonth,' mt WHERE mt.channel_id != 312 ',
' group by mt.user_id) x on css.user_id = x.user_id and css.months = "',year_months,'"',
' set css.channel_num = ifnull(x.chennel_num,0) ');

PREPARE channel FROM @tempChannel;
EXECUTE channel;
-- card send number
SET @tempcard = CONCAT('UPDATE crm_sms_stat css inner join (select mt.user_id,',
' sum(SUBSTRING_INDEX(SUBSTRING_INDEX(mt.dest_mobile, "real", 1),":",-1)) as submit_card_num,',
' sum(SUBSTRING_INDEX(mt.dest_mobile,":",-1)) as real_card_num',
' from ',mt_sms_yearmonth,' mt WHERE mt.channel_id = 312 ',
' group by mt.user_id) x on css.user_id = x.user_id and css.months = "',year_months,'"',
' set css.submit_card_num = ifnull(x.submit_card_num,0),css.real_card_num = ifnull(x.real_card_num,0) ');
PREPARE card FROM @tempcard;
EXECUTE card;
END IF;

END;
 

------分隔线----------------------------
标签(Tag):数据库 MYSQL mysql数据库
------分隔线----------------------------
推荐内容
  • Laravel debug bar 调试利器

    一、简介 Laravel Debugbar 在 Laravel 5 中集成了 PHP Debug Bar ,用于显示调试及错...

  • 如何安装mysql mysql安装图解教程

    本文就是给吊丝程序员介绍的怎么安装mysql的教程一枚,追求高大尚的高帅福可以绕道而...

  • Windows 2008服务器使用Xampps 搭建环境完美整合mod

    一、Xampps Tomcat模块使用中需要jdk支持的安装方法: 由于jdk的包真心大 180MB, 也无...

  • PHP调试利器XDebug的安装与使用基础教程

    很多PHP程序员调试使用echo、print_r()、var_dump()、printf()等,虽然对于有较丰富开...

  • phpstorm创建编辑远程项目实现图解教程

    PhpStorm是一个编辑PHP代码的神器,应该说是目前世界上编辑PHP代码的最好用的IDE了吧...

  • PHP的一种实现基于遗传算法的组卷系统的代码

    遗传算法(Genetic Algorithm,简称GA)是一种模拟达尔文的遗传选择和自然淘汰的生物...

  • 猜你感兴趣
  • 教育技术学动态
  • 教育技术学论文
  • 理论研究
  • 应用研究
  • 资源收藏
  • 百家观点
  • 英文文献
  • 中国电化教育
  • 电化教育研究
  • 中国远程教育
  • 开放教育研究
  • 现代教育技术
  • 远程教育杂志
  • 现代远距离教育
  • 中国教育信息化
  • 中国信息技术教育
  • 中小学信息技术
  • Flash龙8娱乐官网手机版
  • Photoshop龙8娱乐官网手机版
  • 3DMAX龙8娱乐官网手机版
  • AutoCAD龙8娱乐官网手机版
  • CorelDRAW龙8娱乐官网手机版
  • Matlab龙8娱乐官网手机版
  • 其他龙8娱乐官网手机版
  • .Net龙8娱乐官网手机版
  • Asp龙8娱乐官网手机版
  • Php龙8娱乐官网手机版
  • Jsp龙8娱乐官网手机版
  • Ajax龙8娱乐官网手机版
  • Android教程
  • 其他龙8娱乐官网手机版
  • Word教程
  • Excel教程
  • PowerPoint教程
  • Ubuntu教程
  • 其他教程
  • 课件下载
  • 软件下载
  • 视频教程下载
  • 其他下载
  • 教案大全
  • 试题大全
  • 课件大全
  • 其他大全
  • 人像摄影
  • 风光摄影