『转』MySQL存储过程语法例子
原文地址:http://blog.chinaunix.net/uid-540802-id-138873.html
------------------------- 自动生成随机数据存储过程 -------------------------
drop PROCEDURE if exists genRand;
delimiter //
create PROCEDURE genRand(in rank int, in add_num int, in statTime char(10))
-- rank:随机最大邮件数, add_num:生成条数, startTime:统计数据日期
Begin
declare mobile long;
declare tmp int;
set mobile = 13600000000;
set tmp = 1;
-- delete from ippush_stats_email;
while tmp <= add_num do
insert into ippush_stats_email values(mobile + tmp, 1, now(), statTime,
random_int(rank), random_int(rank), random_int(rank), random_int(rank),random_int(rank),
random_int(rank), random_int(rank), random_int(rank), random_int(rank),random_int(rank),
random_int(rank), random_int(rank), random_int(rank), random_int(rank),random_int(rank),
random_int(rank), random_int(rank), random_int(rank), random_int(rank),random_int(rank),
random_int(rank), random_int(rank), random_int(rank), random_int(rank) );
set tmp = tmp + 1;
end while;
end//
delimiter ;
call genRand(10, 10, '2010-10-6');
------------------------- 统计从time1到time2时段的 -------------------------
drop PROCEDURE if exists doStats;
delimiter //
create PROCEDURE doStats(in time1 char(10), in time2 char(10))
Begin
declare _mobile char(11);
declare _sums int;
declare _stat_time date;
declare _count int;
declare _user_type int;
declare fetchSeqOk int;
declare fetchSeqCursor cursor for
select mobile, count(*) as count, user_type, stat_time, max((clock_1 + clock_2 + clock_3+clock_4+clock_5+clock_6+clock_7+clock_8+clock_9+
clock_10+clock_11+clock_12+clock_13+clock_14+clock_15+clock_16+clock_17+clock_18+clock_19+
clock_20+clock_21+clock_22+clock_23+clock_24)) as sums
from ippush_stats_email
where stat_time >= time1 and stat_time <= time2
group by mobile;
declare CONTINUE HANDLER FOR NOT FOUND SET fetchSeqOk = 0;
set fetchSeqOk = 1;
open fetchSeqCursor;
while fetchSeqOk = 1 do
fetch fetchSeqCursor into _mobile, _count, _user_type, _stat_time, _sums;
if _sums > 30 then
call onelineStat(1, _user_type, time1, time2, _mobile);
else
call onelineStat(2, _user_type, time1, time2, _mobile);
end if;
end while;
close fetchSeqCursor;
end//
delimiter ;
call doStats('2010-10-01', '2010-11-05');
------------------------- 一条业务线的统计 --------------------------
drop PROCEDURE if exists onelineStat;
delimiter //
create PROCEDURE onelineStat(in type int, in inuser_type int, in time1 char(10), in time2 char(10), in inmobile char(11))
Begin
if inuser_type = 1 then -- is mas user
if type = 1 then -- is level 1
insert into ippush_strategy (select mobile, inuser_type, concat(max(clock_1)>=4,
max(clock_2)>=4,
max(clock_3)>=4,
max(clock_4)>=4,
max(clock_5)>=4,
max(clock_6)>=4,
max(clock_7)>=4,
max(clock_8)>=4,
'111111111',
max(clock_19)>=4,
max(clock_20)>=4,
max(clock_21)>=4,
max(clock_22)>=4,
max(clock_23)>=4,
max(clock_24)>=4), now(), time1, time2
from ippush_stats_email
where mobile = inmobile and stat_time >= time1 and stat_time <= time2 and user_type = inuser_type
group by mobile ) ;
else
insert into ippush_strategy ( select mobile, inuser_type, concat(max(clock_1)>=4,
max(clock_2)>=4,
max(clock_3)>=4,
max(clock_4)>=4,
max(clock_5)>=4,
max(clock_6)>=4,
max(clock_7)>=4,
max(clock_8)>=4,
max(clock_9)>=4,
max(clock_10)>=4,
max(clock_11)>=4,
max(clock_12)>=4,
max(clock_13)>=4,
max(clock_14)>=4,
max(clock_15)>=4,
max(clock_16)>=4,
max(clock_17)>=4,
max(clock_18)>=4,
max(clock_19)>=4,
max(clock_20)>=4,
max(clock_21)>=4,
max(clock_22)>=4,
max(clock_23)>=4,
max(clock_24)>=4), now(), time1, time2
from ippush_stats_email
where mobile = inmobile and stat_time >= time1 and stat_time <= time2 and user_type = inuser_type
group by mobile ) ;
end if;
else -- is mig user
if type = 1 then
insert into ippush_strategy values(inmobile, inuser_type, '111111111111111111111111', now, time1, time2);
end if;
end if;
end//
delimiter ;
------------------ 调用 --------------------
call onelineStat(1, 1, '2010-10-01', '2010-11-05', '13600000001');
『转』MySQL存储过程语法例子的更多相关文章
- mysql存储过程语法及实例
存储过程如同一门程序设计语言,同样包含了数据类型.流程控制.输入和输出和它自己的函数库. --------------------基本语法-------------------- 一.创建存储过程cr ...
- Mysql存储过程语法
一口气弄完了! 一.条件语句if-then-else: create procedure demo_1(in param int) begin declare var int; ; then inse ...
- 『007』MySQL
『005』索引-Database MySQL [001]- 点我快速打开文章[第一章 MySQL 大纲介绍] [002]- 点我快速打开文章[第二章 MySQL 介绍和安装] 更新中
- mysql存储过程简单例子
1.之前经常在oracle数据库中使用存储过程,换到mysql后用的不多,但是有时候也用,大致记录一下,基本和oracle的一样. CREATE DEFINER = `root`@`%` PROCED ...
- Mysql 存储过程小例子
创建存储过程: DELIMITER $$ USE `database_name`$$ DROP PROCEDURE IF EXISTS `add_or_update_user`$$ )) BEGIN ...
- 重新学习MySQL数据库2:『浅入浅出』MySQL 和 InnoDB
重新学习Mysql数据库2:『浅入浅出』MySQL 和 InnoDB 作为一名开发人员,在日常的工作中会难以避免地接触到数据库,无论是基于文件的 sqlite 还是工程上使用非常广泛的 MySQL.P ...
- 『浅入浅出』MySQL 和 InnoDB
作为一名开发人员,在日常的工作中会难以避免地接触到数据库,无论是基于文件的 sqlite 还是工程上使用非常广泛的 MySQL.PostgreSQL,但是一直以来也没有对数据库有一个非常清晰并且成体系 ...
- Mysql 存储过程基本语法
delimiter //一般情况下MYSQL以:结尾表示确认输入并执行语句,但在存储过程中:不是表示结束,因此可以用该命令将:号改为//表示确认输入并执行. 一.创建存储过程 1.基本语法: crea ...
- mysql 调用存储过程及例子
存储过程如同一门程序设计语言,同样包含了数据类型.流程控制.输入和输出和它自己的函数库. --------------------基本语法-------------------- 一.创建存储过程 c ...
随机推荐
- Linux高可靠技术
1.进程挂死时,有后台监控程序检测重新拉起. 2.进程占用系统资源超过ulimit限定的资源时,会被ulimit杀死,同时配合后台监控程序,重新拉起进程,实现进程可靠性. 3.Linux系统的高可靠性 ...
- loadrunner 运行脚本-Run-time Settings之Preferences设置
运行脚本-Run-time Settings之Preferences设置 by:授客 QQ:1033553122 打开Preferences设置对话框,这里提供了对运行时的参数选择设置 Enable ...
- Linux 学习笔记之超详细基础linux命令 Part 4
Linux学习笔记之超详细基础linux命令 by:授客 QQ:1033553122 ---------------------------------接Part 3----------------- ...
- loadrunner 场景设计-学习笔记之性能误区
场景设计-学习笔记之性能误区 by:授客 QQ:1033553122 场景假设: 每个事务仅包含一次请求,执行10000个并发用户数 性能误区: 每秒并发用户数=每秒向服务器提交请求数 详细解答: 每 ...
- Android NDK编译之undefined reference to 'JNI_CreateJavaVM'
利用Android NDK编译动态库,在C文件中调用了两个JNI函数:JNI_GetDefaultJavaVMInitArgs和JNI_CreateJavaVM.编译的时候始终报以下错误: XXX: ...
- JavaScript按纯数字排序
直接上代码: var arr=[ {name:"张散步",age:"23",sports:"篮球",number:"23112 ...
- (网页)java中Collections.sort排序详解(转)
转自CSDN: Comparator是个接口,可重写compare()及equals()这两个方法,用于比价功能:如果是null的话,就是使用元素的默认顺序,如a,b,c,d,e,f,g,就是a,b, ...
- (小技巧)Sql server查看sql语句的执行时间(转)
转自CSDN: 在写数据库sql的时候,我们往往很关心该sql语句的执行效率,如下小技巧可以帮助程序员简单快速的得到某条或某几条sql的执行时间. declare @d datetime set @d ...
- 关于string指针
string str("hello world"); string *pstr = &str; cout << pstr[0] << endl; c ...
- MySQL 并行复制演进及 MySQL 8.0 中基于 WriteSet 的优化
MySQL 8.0 可以说是MySQL发展历史上里程碑式的一个版本,包括了多个重大更新,目前 Generally Available 版本已经已经发布,正式版本即将发布,在此将介绍8.0版本中引入的一 ...