mysql存储过程和存储函数
mysql存储过程和存储函数
存数函数
代码示例:DROP PROCEDURE IF EXISTS calc_ci_day_suc_rate;
delimiter //
CREATE FUNCTION calc_ci_day_suc_rate(dt DATE, exp_version VARCHAR(64)) RETURNS FLOAT
BEGIN
DECLARE oneDayCICount INT DEFAULT 0;
DECLARE oneDaySucCICount INT DEFAULT 0;
DECLARE CISucRate FLOAT DEFAULT -1.0;
SELECT COUNT(build_id) INTO oneDayCICount FROM versions_build_info WHERE version_name = exp_version AND DATEDIFF(generate_time, dt) = 0;
IF(oneDayCICount != 0) THEN
SELECT COUNT(distinct(build_id)) INTO oneDaySucCICount FROM build_detail WHERE build_detail where result=1 and build_id in (select build_id from versions_build_info where version_name = exp_version and DATEDIFF(generate_time, dt) = 0);
SET CISucRate = oneDaySucCICount*100/oneDayCICount;
END IF
RETURN CISucRate
END
//
delimiter ;
其中的delimiter是改变mysql命令行中;结束符为//,当然,也可以改为其他的符号
存储函数创建的基本格式为:CREATE FUNCTION 函数名(参数名 类型, 参数名 类型)RETURNS 返回值类型
BEGIN
DECLARE 参数名 类型 [DEFAULT 值];
IF(表达式) THEN
SET 变量名 = 值;
ELSEIF(表达式) THEN
语句块;
ELSE
语句块;
END IF;
WHILE 表达式 DO
语句块;
END WHILE;
RETURN 参数名;
END
- CREATE FUNCTION是表示创建的是存储函数,后跟函数名和参数
- RETURNS后面跟的是返回值的类型
- 函数体是以BEGIN开始,END结束
- 函数中局部变量的声明使用DECLARE,类型就是mysql支持的类型,可以通过DEFAULT指定缺省值
- 变量的赋值通过SET进行
- IF来进行条件判断,以END IF结束
- WHILE循环以END WHILE结束
存储过程
代码示例:DROP PROCEDURE IF EXISTS cacl_all_ci_suc_rate;
delimiter //
CREATE PROCEDURE cacl_all_ci_suc_rate(IN exp_version VARCHAR(64))
BEGIN
DECLARE beginDate DATETIME DEFAULT '2015-01-01';
DECLARE caclDate DATE;
DECLARE CISucRate FLOAT DEFAULT -1.0;
DECLARE oneDayCICount INT DEFAULT 0;
DECLARE oneDayFailCICount INT DEFAULT 0;
DECLARE oneDaySucCICount INT DEFAULT 0;
SELECT MIN(generate_time) INTO beginDate FROM versions_build_info;
IF(DATEDIFF(beginDate, '2015-01-01') != 0) THEN
SET caclDate = DATE(beginDate);
WHILE DATEDIFF(CURDATE(), caclDate) > 0 DO
SELECT get_one_day_total_ci_count(caclDate, exp_version) INTO oneDayCICount;
IF(oneDayCICount != 0) THEN
SELECT get_one_day_fail_ci_count(caclDate, exp_version) INTO oneDayFailCICount;
SET oneDaySucCICount = oneDayCICount - oneDayFailCICount;
SET CISucRate = oneDaySucCICount*100/oneDayCICount;
INSERT INTO rmp_daily_build_ci(ci_date, suc_percent, build_count, suc_count) VALUES(caclDate, CISucRate, oneDayCICount, oneDaySucCICount);
END IF;
SET caclDate = ADDDATE(caclDate, 1);
END WHILE;
END IF;
END
//
delimiter ;
- CREATE PROCEDURE表示创建存储过程
- 参数可以通过IN和OUT来表示参数是输入参数还是输出参数,INOUT表示既是输入也是输出
- 没有返回值
- 其他语法与创建存数函数一样
mysql存储过程和存储函数的更多相关文章
- mysql 存储过程和存储函数
14.1.1 创建存储过程 MySQL中,创建存储过程的基本形式如下: CREATE PROCEDURE sp_name ([proc_parameter[,...]]) [characteristi ...
- MySQL 存储过程和存储函数学习
#一.存储过程和存储函数的创建案例 CREATE PROCEDURE myprocedure(in a int,in b int ,OUT c INT) BEGIN set c=a+b; end; c ...
- MySQL 存储过程和存储函数 的定义条件和处理程序
#三.定义条件和处理程序 #mysql 存储函数和过程可以将错误 变成我们想要的处理结果分2步骤 #1.定义错误条件 语法:DECLARE 条件名字 CONDITION for 错误编码 #2. 定义 ...
- mysql 存储过程与存储函数
第一节:存储过程和函数的引入 存储过程和函数是在数据库中定义一些SQL 语句的集合,然后直接调用这些存储过程和函数来执行已经定义好的SQL 语句.存储过程和函数可以避免开发人员重复的编写相同的SQL ...
- MySQL存储过程与存储函数的区别
语法定义上的区别就不说了,说一下其他的.如果有不正确的地方,还请大家指正. 1.总述存储函数和存储过程统称为存储例程(stored routine).两者的定义语法很相似,但却是不同的内容.存储函数限 ...
- MySQL数据库之存储过程与存储函数
1 引言 存储过程和存储函数类似于面向对象程序设计语言中的方法,可以简化代码,提高代码的重用性.本文主要介绍如何创建存储过程和存储函数,以及存储过程与函数的使用.修改.删除等操作. 2 存储过程与存储 ...
- Mysql数据库(八)存储过程与存储函数
一.创建存储过程与存储函数 1.创建存储过程(实现统计tb_borrow1数据表中指定图书编号的图书的借阅次数) mysql> delimiter // mysql> CREATE PRO ...
- mysql存储过程及常用函数
原文:mysql存储过程及常用函数 一.函数 1.数学函数 CEIL()进一取整 SELECT CEIL(1.2);2 FLOOR()舍一取整 SELECT FLOOR(1.9);9 MOD取余数(取 ...
- Oracle03——游标、异常、存储过程、存储函数、触发器和Java代码访问Oracle对象
作者: kent鹏 转载请注明出处: http://www.cnblogs.com/xieyupeng/p/7476717.html 1.游标(光标)Cursor 在写java程序中有集合的概念,那么 ...
随机推荐
- 禁用Windows重复数据删除
重复数据删除,可以减少磁盘占用,但使用不当也有可能增加IO,另外,也为此功能会将硬盘分块,所以当硬盘占用较高时,进行碎片整理也比较困难,所以有时需要禁用掉重复数据删除功能,并解除重复数据的优化,可以通 ...
- Ural 1225. Flags 斐波那契DP
1225. Flags Time limit: 1.0 secondMemory limit: 64 MB On the Day of the Flag of Russia a shop-owner ...
- [KMP]【学习笔记】
Oulipo Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 36916 Accepted: 14904 Descript ...
- 《虚拟伙伴》AR增强现实应用开发总结
一.概述 1.1选题背景 随着时代的发展,人们的生活节奏越来越快,生活质量也越来越高,但却在繁忙之中忽略或者忘记了关心自己成长时代最重要或者最正确的事情和道理.虽然现在有很多社交平台,如微博,微信,f ...
- 【Git】error: RPC
摘要 git push throws error: RPC failed; result=56, HTTP code = 200的解决办法 原因 默认 Git 设置 http post 的缓存为 ...
- 配置generatorConfig.xml自动生成的代码的sql书写问题
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE generatorConfiguratio ...
- react native 的图表开源组件react-native-chart-android
react-native-chart-android是一个图表开源组件,使用方法可以去这里 由于需要在数据上加上触摸事件,而github上没有说明看源码找了半天才找到下面的解决方法,特此记录一下: 在 ...
- 红米3 SM71.1(android-7.1.1_r6)更新发布20161229年末增强版
一.写在前面 我只是个人爱好,本ROM未集成任何第三方推广软件,我只是喜欢把好的资源分享出来,若可以,我们一起学习,一起进步. 请不要问我怎么刷机! 请不要问我玩游戏卡不卡(有钱你就换好点的手机)! ...
- Mysql 修改字段默认值
环境:MySQL 5.7.13 问题描述:建表的时候,users_info表的role_id字段没有默认值,后期发现注册的时候,需要提供给用户一个默认角色,也就是给role_id字段一个默认值. 当前 ...
- Java时间类型转换
String转Long Long long=new SimpleDateFormat("yyyyMMddHHmmss").parse(String).getTime(); Long ...