`
taiwei.peng
  • 浏览: 233986 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

mysql 存储过程

 
阅读更多

1.带游标的存储过程

DROP PROCEDURE  IF EXISTS `sp_message_his`; 

CREATE PROCEDURE `sp_message_his`(IN `msg_id` int) 

 

BEGIN 

  -- 用户id -- 

  declare v_userid bigint(20);

  -- 遍历数据结束标志

  DECLARE done INT DEFAULT FALSE;

  -- 查询推送方式为1的所有用户id

  declare cur cursor for SELECT t.userID from devicetoken t where t.pushtype=1;

  -- 将结束标志绑定到游标

  DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE;

 

  -- 打开游标

  OPEN cur;

   -- 开始循环

   read_loop: LOOP

    -- 提取游标里的数据,这里只有一个,多个的话也一样;

    FETCH cur INTO v_userid;

    -- 声明结束的时候

    IF done THEN

      LEAVE read_loop;

    END IF;

    -- 这里做你想做的循环的事件

    INSERT INTO suinfouser(userID,infoID,readed) values (v_userid,msg_id,0);

  END LOOP;

  -- 关闭游标

  CLOSE cur;

END

 

 

DROP PROCEDURE  IF EXISTS `sp_choose_his`; 

CREATE PROCEDURE `sp_choose_his`() 

BEGIN 

   DECLARE v_customerId int;

   DECLARE v_regtime date;

   DECLARE v_order_no VARCHAR(64);

 

   -- 遍历数据结束标志

   DECLARE done INT DEFAULT FALSE;

   -- 查询所有的VIP用户

   DECLARE cur cursor for SELECT t.customerId,left(t.RegTime,10) regtime from cus_customer t where t.GroupId=7

   and t.customerId not in (SELECT DISTINCT t.customer_id from choose_stock_record t where t.pay_status=1 and t.type=4);

   -- 将结束标志绑定到游标

   DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE;

 

   -- 打开游标

   OPEN cur;

   -- 开始循环

   read_loop: LOOP

    -- 提取游标里的数据,这里只有一个,多个的话也一样;

    FETCH cur INTO v_customerId,v_regtime;

    -- 声明结束的时候

    IF done THEN

      LEAVE read_loop;

    END IF;

    select round(round(rand(),12)*10000000000) INTO v_order_no from dual;

    -- 这里做你想做的循环的事件

    INSERT into choose_stock_record(customer_id,order_no,stock_code,start_date,end_date,pay_amount,unit_name,unit_period,pay_time,pay_status,sub_status,type,channel,create_time,remark)

    VALUES(v_customerId,concat(168,v_order_no),'xg_zlzy',v_regtime,date_add(v_regtime, interval 365 day),0,'vip赠送',365,NOW(),1,1,4,1,NOW(),'手动开通选股');

 

    INSERT into choose_stock_record(customer_id,order_no,stock_code,start_date,end_date,pay_amount,unit_name,unit_period,pay_time,pay_status,sub_status,type,channel,create_time,remark)

    VALUES(v_customerId,concat(168,v_order_no),'xg_flzt',v_regtime,date_add(v_regtime, interval 365 day),0,'vip赠送',365,NOW(),1,1,4,1,NOW(),'手动开通选股');

 

    INSERT into choose_stock_record(customer_id,order_no,stock_code,start_date,end_date,pay_amount,unit_name,unit_period,pay_time,pay_status,sub_status,type,channel,create_time,remark)

    VALUES(v_customerId,concat(168,v_order_no),'xg_qlzy',v_regtime,date_add(v_regtime, interval 365 day),0,'vip赠送',365,NOW(),1,1,4,1,NOW(),'手动开通选股');

 

    INSERT into choose_stock_record(customer_id,order_no,stock_code,start_date,end_date,pay_amount,unit_name,unit_period,pay_time,pay_status,sub_status,type,channel,create_time,remark)

    VALUES(v_customerId,concat(168,v_order_no),'dz_xg_slqf',v_regtime,date_add(v_regtime, interval 365 day),0,'vip赠送',365,NOW(),1,1,4,1,NOW(),'手动开通选股');

 

    INSERT into choose_stock_record(customer_id,order_no,stock_code,start_date,end_date,pay_amount,unit_name,unit_period,pay_time,pay_status,sub_status,type,channel,create_time,remark)

    VALUES(v_customerId,concat(168,v_order_no),'dz_xg_ztyc',v_regtime,date_add(v_regtime, interval 365 day),0,'vip赠送',365,NOW(),1,1,4,1,NOW(),'手动开通选股');

 

  END LOOP;

  -- 关闭游标

  CLOSE cur;

   

END;

 

2.普通的存储过程

DROP PROCEDURE  IF EXISTS `sp_timeshar_his`; 

CREATE PROCEDURE `sp_timeshar_his`

BEGIN 

   DECLARE v_cur_Date date;

   DECLARE v_cur_num_sh int;

   DECLARE v_minDate_sh date; 

   DECLARE v_cur_num_sz int;

   DECLARE v_minDate_sz date; 

 

   set v_cur_Date = CURDATE();

   set v_cur_num_sh =0;

   set v_cur_num_sz =0;

   

   -- 查询上海当天是否有数据 -- 

   SELECT count(1) into v_cur_num_sh from stk_timesharing_sh where date=DATE_FORMAT(v_cur_Date,'%Y-%m-%d');

   -- 把数据写入历史表 --

   if v_cur_num_sh>0 THEN 

       INSERT INTO stk_timesharing_sh_bak(ts_id,asset_id,price,avg_price,volume,date,time,create_time) 

       select t.ts_id,t.asset_id,t.price,t.avg_price,t.volume,t.date,t.time,CURTIME() from stk_timesharing_sh t 

       where t.date=DATE_FORMAT(v_cur_Date, '%Y-%m-%d');

   end if ;

   -- 查询最小的日期 --

   select min(a.date) into v_minDate_sh from 

   (SELECT DISTINCT t.date from stk_timesharing_sh t ORDER BY t.date desc LIMIT 8)a;

   -- 删除数据--

   DELETE from stk_timesharing_sh where date<=DATE_FORMAT(v_minDate_sh, '%Y-%m-%d');

 

   -- 查询深圳当天是否有数据 -- 

   SELECT count(1) into v_cur_num_sz from stk_timesharing_sz  where date=DATE_FORMAT(v_cur_Date,'%Y-%m-%d');

    -- 把数据写入历史表 --

   if v_cur_num_sz>0 THEN 

       INSERT INTO stk_timesharing_sz_bak(ts_id,asset_id,price,avg_price,volume,date,time,create_time) 

       select t.ts_id,t.asset_id,t.price,t.avg_price,t.volume,t.date,t.time,CURTIME() from stk_timesharing_sz t 

       where t.date=DATE_FORMAT(v_cur_Date, '%Y-%m-%d');

   end if ;

   -- 查询最小的日期 --

   select min(a.date) into v_minDate_sz from 

   (SELECT DISTINCT t.date from stk_timesharing_sz t ORDER BY t.date desc LIMIT 8)a;

   -- 删除数据--

   DELETE from stk_timesharing_sz where date<=DATE_FORMAT(v_minDate_sz, '%Y-%m-%d');

   

 

END

 

3.有多个循环语句的存储过程

DROP PROCEDURE  IF EXISTS `sp_register_his`; 

CREATE PROCEDURE `sp_register_his`() 

BEGIN 

   DECLARE v_i int unsigned DEFAULT 1;

   DECLARE v_reg_date date;

   DECLARE v_next_date date;

   DECLARE v_cur_date date;

   DECLARE v_j int unsigned DEFAULT 1;

   DECLARE v_first_week VARCHAR(20) DEFAULT '2019-05-06';

   DECLARE v_next_week VARCHAR(20);

   DECLARE v_cur_week  VARCHAR(20);

DECLARE v_m int unsigned DEFAULT 1;

   DECLARE v_first_month VARCHAR(20) DEFAULT '2019-05-01';

   DECLARE v_next_month VARCHAR(20);

   DECLARE v_cur_month VARCHAR(20);

   DECLARE temp_mm VARCHAR(20);

 

SELECT min(left(t.reg_time,10)) into v_reg_date from policy.cus_customer t;

   SELECT date_format(now(),'%y-%m-%d') into v_cur_date from dual;

 

   WHILE v_i < 365 DO

    IF v_reg_date<=v_cur_date THEN 

    -- 注册用户 

    INSERT INTO cus_reg_pool(reg_date,android_reg,ios_reg,total_reg,mobile_reg,wx_reg,qq_reg,ding_reg,facebook_reg,trade_reg,apple_reg,created_time,update_time)

    SELECT

    v_reg_date as regDate,

IFNULL(SUM(CASE WHEN reg_from = 'android' THEN 1 ELSE '0' END ),0) as androidReg,

IFNULL(SUM(CASE WHEN reg_from = 'ios' THEN 1 ELSE '0' END ),0) as iosReg,

    count(1) as totalReg,

IFNULL(SUM(CASE WHEN reg_type = 'mobile' THEN 1 ELSE '0' END ),0) as mobileReg,

IFNULL(SUM(CASE WHEN reg_type ='wx' THEN 1 ELSE '0' END ),0) as wxReg,

IFNULL(SUM(CASE WHEN reg_type ='qq' THEN 1 ELSE '0' END ),0) as qqReg,

IFNULL(SUM(CASE WHEN reg_type ='ding' THEN 1 ELSE '0' END ),0) as dingReg,

IFNULL(SUM(CASE WHEN reg_type ='facebook' THEN 1 ELSE '0' END ),0) as facebookReg,

IFNULL(SUM(CASE WHEN reg_type = 'trade' THEN 1 ELSE '0' END ),0) as tradeReg,

IFNULL(SUM(CASE WHEN reg_type = 'apple' THEN 1 ELSE '0' END ),0) as appleReg,

    NOW(),

    NOW()

from policy.cus_customer t

where left(t.reg_time,10)=v_reg_date;

   

    -- 累计注册用户

    INSERT INTO cus_grand_pool(reg_date,android_reg,ios_reg,total_reg,created_time,update_time)

    SELECT

    v_reg_date,

IFNULL(SUM(CASE WHEN reg_from = 'android' THEN 1 ELSE '0' END ),0) as androidReg,

IFNULL(SUM(CASE WHEN reg_from = 'ios' THEN 1 ELSE '0' END ),0) as iosReg,

    count(1) as totalReg,

    NOW(),

    NOW()

from policy.cus_customer t

    where left(t.reg_time,10)<=v_reg_date;

 

    -- 注册用户日表

    INSERT INTO cus_day_report(login_date,total_login,android_login,ios_login,type,created_time,update_time)

    SELECT r.reg_date,r.total_reg,r.android_reg,r.ios_reg,1,now(),now() from cus_reg_pool r where r.reg_date=v_reg_date;

 

    -- 累计注册用户日表

    INSERT INTO cus_day_report(login_date,total_login,android_login,ios_login,type,created_time,update_time)

    SELECT g.reg_date,g.total_reg,g.android_reg,g.ios_reg,2,now(),now() from cus_grand_pool g where g.reg_date=v_reg_date;

   

    END IF;

    -- 日期加1 

    SELECT date_add(v_reg_date, interval 1 day) into v_next_date from dual;

    SET v_i = v_i+1;

    set v_reg_date=v_next_date;

   END WHILE;

 

   -- 获取最小的月份 

   SELECT MONTH(min(t.login_date)) into temp_mm from cus_day_report t where t.type=1;

   IF temp_mm = 7  THEN  

      set v_first_week='2019-07-01';

      set v_first_month='2019-07-01';

   ELSEIF temp_mm = 8  THEN  

      set v_first_week='2019-07-29';

      set v_first_month='2019-08-01'; 

   ELSEIF temp_mm = 9  THEN

      set v_first_week='2019-09-02';

      set v_first_month='2019-09-01';

ELSEIF temp_mm = 10  THEN

      set v_first_week='2019-09-30';

      set v_first_month='2019-10-01';

   ELSEIF temp_mm = 11  THEN

      set v_first_week='2019-10-28';

      set v_first_month='2019-11-01';

   ELSE  

      set v_first_week='2019-11-25';

      set v_first_month='2019-12-01';  

   END IF;

 

  -- 周表 

  WHILE v_j <60 DO

     -- 获取当前时间的周一

     select subdate(curdate(),date_format(curdate(),'%w')-1) into v_cur_week from dual;

     SELECT DATE_ADD(v_first_week, INTERVAL 1 WEEK) into v_next_week FROM dual;

     IF v_first_week<=v_cur_week THEN 

        -- 注册用户

INSERT INTO cus_week_report(login_date,total_login,android_login,ios_login,type,created_time,update_time)

select v_first_week,IFNULL(sum(t.total_login),0),IFNULL(sum(t.android_login),0),IFNULL(sum(t.ios_login),0),1,NOW(),NOW()

from cus_day_report t where t.login_date>=v_first_week and t.login_date<v_next_week and t.type=1;

 

-- 累计注册用户

        INSERT INTO cus_week_report(login_date,total_login,android_login,ios_login,type,created_time,update_time)

select v_first_week,t.total_login,t.android_login,t.ios_login,2,NOW(),NOW()

from cus_day_report t where t.login_date>=v_first_week and t.login_date<v_next_week and t.type=2 ORDER BY t.id DESC LIMIT 1;

 

END IF;

     SET v_j = v_j+1;

     SET v_first_week=v_next_week;

  END WHILE;

 

  -- 月表

  WHILE v_m < 14 DO

   -- 获取当前时间的月初第一天

   select date_add(curdate(), interval - day(curdate()) + 1 day) into v_cur_month from dual;

   SELECT DATE_ADD(v_first_month, INTERVAL 1 MONTH) into v_next_month FROM dual;

   IF v_first_month<=v_cur_month THEN 

      -- 注册用户

INSERT INTO cus_month_report(login_date,total_login,android_login,ios_login,type,created_time,update_time)

select v_first_month,IFNULL(sum(t.total_login),0),IFNULL(sum(t.android_login),0),IFNULL(sum(t.ios_login),0),1,NOW(),NOW()

from cus_day_report t where t.login_date>=v_first_month and t.login_date<v_next_month and t.type=1;

      

      -- 累计注册用户

      INSERT INTO cus_month_report(login_date,total_login,android_login,ios_login,type,created_time,update_time)

select v_first_month,t.total_login,t.android_login,t.ios_login,2,NOW(),NOW()

from cus_day_report t where t.login_date>=v_first_month and t.login_date<v_next_month and t.type=2 ORDER BY t.id DESC LIMIT 1;

END IF;

   SET v_m = v_m+1;

   SET v_first_month=v_next_month;

  END WHILE;

 

  -- 注册用户年表

  INSERT INTO cus_year_report(login_date,total_login,android_login,ios_login,type,created_time,update_time)

  select '2019-01-01',sum(t.total_login),sum(t.android_login),sum(t.ios_login),1,NOW(),NOW()

  from cus_month_report t where t.login_date>='2019-01-01' and t.login_date<'2020-01-01' and t.type=1;

    

  INSERT INTO cus_year_report(login_date,total_login,android_login,ios_login,type,created_time,update_time)

  select '2020-01-01',sum(t.total_login),sum(t.android_login),sum(t.ios_login),1,NOW(),NOW()

  from cus_month_report t where t.login_date>='2020-01-01' and t.type=1;

 

  -- 累计注册用户年表

  INSERT INTO cus_year_report(login_date,total_login,android_login,ios_login,type,created_time,update_time)

  select '2019-01-01',t.total_login,t.android_login,t.ios_login,2,NOW(),NOW()

  from cus_month_report t where t.login_date='2019-12-01' and t.type=2;

 

  INSERT INTO cus_year_report(login_date,total_login,android_login,ios_login,type,created_time,update_time)

  select '2020-01-01',t.total_login,t.android_login,t.ios_login,2,NOW(),NOW()

  from cus_month_report t where DATE_FORMAT(t.login_date,'%Y%m') = DATE_FORMAT(CURDATE(),'%Y%m') and t.type=2;

 

  -- 初始化其他类型周报

  INSERT INTO `cus_week_report`(login_date,total_login,android_login,ios_login,type,created_time,update_time)

  select subdate(curdate(),date_format(curdate(),'%w')-1),0,0,0,3,NOW(),NOW();

 

  INSERT INTO `cus_week_report`(login_date,total_login,android_login,ios_login,type,created_time,update_time)

  select subdate(curdate(),date_format(curdate(),'%w')-1),0,0,0,4,NOW(),NOW();

 

  INSERT INTO `cus_week_report`(login_date,total_login,android_login,ios_login,type,created_time,update_time)

  select subdate(curdate(),date_format(curdate(),'%w')-1),0,0,0,5,NOW(),NOW();

 

  -- 初始化其他类型月报

  INSERT INTO `cus_month_report`(login_date,total_login,android_login,ios_login,type,created_time,update_time)

  select date_add(curdate(), interval - day(curdate()) + 1 day),0,0,0,3,NOW(),NOW();

 

  INSERT INTO `cus_month_report`(login_date,total_login,android_login,ios_login,type,created_time,update_time)

  select date_add(curdate(), interval - day(curdate()) + 1 day),0,0,0,4,NOW(),NOW();

 

  INSERT INTO `cus_month_report`(login_date,total_login,android_login,ios_login,type,created_time,update_time)

  select date_add(curdate(), interval - day(curdate()) + 1 day),0,0,0,5,NOW(),NOW();

 

  -- 初始化其他类型年报

  INSERT INTO `cus_year_report`(login_date,total_login,android_login,ios_login,type,created_time,update_time)

  VALUES ('2020-01-01', '0', '0', '0', '3', '2020-05-01 00:00:01', '2020-05-01 23:00:05');

 

  INSERT INTO `cus_year_report`(login_date,total_login,android_login,ios_login,type,created_time,update_time)

  VALUES ('2020-01-01', '0', '0', '0', '4', '2020-05-01 00:00:01', '2020-05-01 23:00:05');

 

  INSERT INTO `cus_year_report`(login_date,total_login,android_login,ios_login,type,created_time,update_time)

  VALUES ('2020-01-01', '0', '0', '0', '5', '2020-05-01 00:00:01', '2020-05-01 23:00:05');

END;

 

分享到:
评论

相关推荐

    mysql存储过程之返回多个值的方法示例

    本文实例讲述了mysql存储过程之返回多个值的方法。分享给大家供大家参考,具体如下: mysql存储函数只返回一个值。要开发返回多个值的存储过程,需要使用带有INOUT或OUT参数的存储过程。咱们先来看一个orders表它的...

    mysql存储过程教程

    MySQL存储过程是数据库管理系统中的一种重要功能,它允许开发者预编译一系列SQL语句并封装成一个可重复使用的单元,从而提高数据处理的效率和代码的复用性。本教程将深入探讨MySQL存储过程的创建、调用以及相关概念...

    mysql经典教程+mysql存储过程讲解

    本教程结合"mysql经典教程+mysql存储过程讲解"的主题,将深入探讨MySQL的基础知识以及核心特性——存储过程。 首先,我们需要理解什么是数据库。数据库是一个组织和存储数据的系统,允许用户以结构化方式访问和管理...

    MySQL存储过程的异常处理方法

    本实例展示了如何在MySQL存储过程中实现异常处理,以捕获并处理可能出现的错误。 首先,我们注意到在创建存储过程`myProc`时,使用了`delimiter $$`来改变MySQL客户端的语句分隔符,这是为了在存储过程中使用多个...

    Java实现调用MySQL存储过程详解

    总的来说,Java通过JDBC调用MySQL存储过程涉及到连接数据库、创建`CallableStatement`、执行存储过程和处理结果。这使得开发者能够在Java应用中灵活地利用数据库提供的强大功能,实现更高效的数据处理。

    Mysql存储过程常用语句模板

    Mysql存储过程常用语句模板(含变量,if,三种循环等等) Mysql存储过程常用语句模板(含变量,if,三种循环等等) Mysql存储过程常用语句模板(含变量,if,三种循环等等) Mysql存储过程常用语句模板(含变量,if,三...

    mysql中文手册+mysql命令大全+mysql存储过程

    最后,"mysql存储过程.pdf"专注于MySQL的存储过程。存储过程是预编译的SQL语句集合,可以提高数据库操作的性能,减少网络流量,并增强数据安全。在PDF文档中,你将学习如何定义、调用和管理存储过程,以及如何使用...

    MySQL存储过程编程.pdf

    MySQL 存储过程编程 MySQL 存储过程编程是指在 MySQL 数据库中使用存储过程来实现业务逻辑的编程技术。存储过程是一种可以在数据库中存储和执行的程序单元,它可以实现复杂的业务逻辑和数据处理操作。 在 MySQL ...

    MySQL存储过程学习

    MySQL存储过程是数据库管理系统中的一种重要功能,它允许开发者预编译一系列的SQL语句,形成一个可重复使用的代码块,以提高数据处理的效率和应用程序的性能。在这个"MySQL存储过程学习"的主题中,我们将深入探讨...

    MySQL 存储过程入门到精通

    MySQL存储过程是数据库管理系统中的一个重要特性,它允许程序员或数据库管理员预先定义一组SQL语句,形成一个可重用的逻辑单元。在这个“MySQL存储过程入门到精通”资料中,你将深入理解存储过程的原理、创建、调用...

    c++实现调mysql存储过程

    c++实现调mysql存储过程,实现存储过程的出参入参,可以支持查询多数据返回,还有存储过程的复杂数据的增删改等

    mysql存储过程调试工具

    MySQL存储过程是数据库管理系统中的一种重要功能,它允许开发者编写一系列复杂的SQL语句,并作为一个单元进行执行,提高代码复用性和效率。然而,与普通的编程语言一样,存储过程的调试同样至关重要,因为错误的存储...

    mysql存储过程实例

    MySQL 存储过程实例 MySQL 存储过程实例详细介绍了 MySQL 存储过程的开发步骤,本节将通过具体的实例讲解 PHP 是如何操纵 MySQL 存储过程的。 创建存储过程 存储过程的创建是 MySQL 存储过程的基础,MySQL 5.0 ...

    mysql存储过程实现分页

    ### MySQL存储过程实现分页 #### 背景与需求 在数据库操作中,分页是一种常见的需求,尤其是在处理大量数据时。通过分页技术,可以有效地减少每次查询的数据量,提高系统的响应速度和用户体验。MySQL作为一种广泛...

    mysql 存储过程 实战

    ### MySQL存储过程实战知识点 #### 一、存储过程概述 MySQL 存储过程是一种预编译的 SQL 脚本,它可以包含复杂的逻辑控制结构、循环等操作,并且可以接受参数,执行完后还可以返回结果。存储过程可以提高数据处理...

    MySQL存储过程编程教程.pdf

    MySQL存储过程编程是数据库应用开发中的一个重要环节,它可以帮助开发者将一系列的数据库操作封装起来,以提高程序的可维护性和运行效率。在MySQL 5.0及以上版本中,存储过程、函数和触发器的支持为数据库提供了更...

Global site tag (gtag.js) - Google Analytics