MySQL 第八篇:自定义函数、存储过程、游标
2017-10-29 16:15
1106 查看
本篇内容由猿道教育的课程内容整理而来。
我把MySQL的内容整理成9篇博客,学完这9篇博客虽不能说能成为大神,但是应付一般中小企业的开发已经足够了,有疑问或建议的欢迎留言讨论。
[存储过程选项]
begin
存储过程语句块
end;
说明:
IN 输入参数:表示该参数的值必须在调用存储过程时指定,在存储过程中修改该参数的值不能被返回,为默认值。
OUT 输出参数:该值可在存储过程内部被改变,并可返回。
INOUT 输入输出参数:调用时指定,并且可被改变和返回。
存储过程和函数存在以下几个区别:
1)一般来说,存储过程实现的功能要复杂一点,而函数的实现的功能针对性比较强。存储过程,功能强大,可以执行包括修改表等一系列数据库操作;用户定义函数不能用于执行一组修改全局数据库状态的操作。
2)对于存储过程来说可以返回参数,如记录集,而函数只能返回值或者表对象。函数只能返回一个变量;而存储过程可以返回多个。存储过程的参数可以有IN,OUT,INOUT三种类型,而函数只能有IN类~~存储过程声明时不需要返回类型,而函数声明时需要描述返回类型,且函数体中必须包含一个有效的RETURN语句。
3)存储过程,可以使用非确定函数,不允许在用户定义函数主体中内置非确定函数。
4)(mysql除外)存储过程一般是作为一个独立的部分来执行( EXECUTE 语句执行),而函数可以作为查询语句的一个部分来调用(SELECT调用),由于函数可以返回一个表对象,因此它可以在查询语句中位于FROM关键字的后面。 SQL语句中不可用存储过程,而可以使用函数。
2.打开游标 open 游标名。
3.从游标中提取数据 fetch 游标名 into 标量(需配合循环使用)。
4.关闭游标 close 游标名称。
注意:
1.变量名的个数必须与声明游标时使用的select语句结果集中的字段个数保持一致
2.fetch 在执行过程中如果无法提取数据会产生 “ERROR 1329(0200):Nodata to FETCH”,这样我们可以自定义1329错误来结束遍历。
我把MySQL的内容整理成9篇博客,学完这9篇博客虽不能说能成为大神,但是应付一般中小企业的开发已经足够了,有疑问或建议的欢迎留言讨论。
自定义函数
一、函数的概念与定义
1、理解函数
函数可以看作是一个加工作坊,这个加工作坊接收调用者传递过来的原料(传递的参数),然后将这些原料加工处理成产品(函数的返回值)再把产品返回给调用者。2、创建语法(建议自定义函数以fun_前缀)
create function 函数名(参数1,参数2....) returns 返回值的数据类型 [函数类型] begin 函数体 return 语句; end;
-- 将日期转换成2017年10月29日 -- DELIMITER $$的作用是声明sql语句以$$结束,也可以把$$换成其他符号,在这里可以省略,如果是命令行运行就一定要加上。 DELIMITER $$ create function fun_dateToStr(mdate datetime)returns varchar(50) BEGIN -- 声明一个变量 使用declare 变量名 数据类型 默认值 declare str varchar(50) default ''; -- 使用set 对变量进行赋值 set str = DATE_FORMAT(mdate,'%Y年%m月%d日'); return str; end $$ DELIMITER ;
-- 使用函数 select *,fun_dateToStr(NOW()) from students
二、自定义函数
1、DELIMITER
定义一个结束标识符,因为MySQL默认是以分号作为SQL语句的结束符的,而函数体内部要用到分号,所以会跟默认的SQL结束符发生冲突,所以需要先定义一个其他的符号作为SQL的结束符;2、分支结构
IF 条件 THEN 语句 ELSEIF 条件 THEN 语句 ELSE 语句 END IF;
DELIMITER $$ CREATE FUNCTION FUN_getAgeStr(age int) RETURNS varchar(20) BEGIN declare results varchar(20); IF age<16 then set results = '小屁孩'; ELSEIF age <22 THEN set results = '小鲜肉'; ELSEIF age <30 THEN set results = '小青年'; ELSE SET results = '大爷'; END IF; RETURN results; end $$ DELIMITER ; select *,FUN_getAgeStr(age) from students;
3、循环结构
循环名:loop end loop 循环名 WHILE,REPEAT
DELIMITER $$ create function fun_loop(nums int) returns varchar(255) BEGIN DECLARE i int default 0; DECLARE result varchar(255) default ''; -- 循环的开始,冒号前面是一个循环名 colorLoop:LOOP SET i = i+1; SET result = concat(result,'Color '); -- 跳出循环 IF i >= nums THEN LEAVE colorLoop; END IF; -- 结束循环 END LOOP colorLoop; return result; end $$ DELIMITER ; select fun_loop(4)
4、删除自定义函数
DROP FUNCTION IF EXISTS 自定义函数名
drop function if exists FUN_getAgeStr;
5、查看自定义函数定义
SHOW CREATE FUNTION 自定义函数名;
6、查看自定义函数状态
SHOW FUNCTION STATUS [LIKE]
存储过程
一、创建语法(建议自定义函数以pro_前缀)
create procedure 存储过程名(参数1,参数2…)[存储过程选项]
begin
存储过程语句块
end;
说明:
IN 输入参数:表示该参数的值必须在调用存储过程时指定,在存储过程中修改该参数的值不能被返回,为默认值。
OUT 输出参数:该值可在存储过程内部被改变,并可返回。
INOUT 输入输出参数:调用时指定,并且可被改变和返回。
create procedure pro_dealStudents(in s_id varchar(50)) BEGIN set @s_id = s_id; select * from students s where s.s_id=@s_id; end; -- 使用存储过程 CALL pro_dealStudents('J1604028');
二、存储过程与函数的区别
存储过程是用户定义的一系列sql语句的集合,涉及特定表或其它对象的任务,用户可以调用存储过程,而函数通常是数据库已定义的方法,它接收参数并返回某种类型的值并且不涉及特定用户表。存储过程和函数存在以下几个区别:
1)一般来说,存储过程实现的功能要复杂一点,而函数的实现的功能针对性比较强。存储过程,功能强大,可以执行包括修改表等一系列数据库操作;用户定义函数不能用于执行一组修改全局数据库状态的操作。
2)对于存储过程来说可以返回参数,如记录集,而函数只能返回值或者表对象。函数只能返回一个变量;而存储过程可以返回多个。存储过程的参数可以有IN,OUT,INOUT三种类型,而函数只能有IN类~~存储过程声明时不需要返回类型,而函数声明时需要描述返回类型,且函数体中必须包含一个有效的RETURN语句。
3)存储过程,可以使用非确定函数,不允许在用户定义函数主体中内置非确定函数。
4)(mysql除外)存储过程一般是作为一个独立的部分来执行( EXECUTE 语句执行),而函数可以作为查询语句的一个部分来调用(SELECT调用),由于函数可以返回一个表对象,因此它可以在查询语句中位于FROM关键字的后面。 SQL语句中不可用存储过程,而可以使用函数。
游标
游标本质上是一种能从select结果集中每次提取一条记录的机制,因此游标与select语句息息相关。一、使用游标的步骤:
1.声明游标 declare 游标名 cursor for select语句。2.打开游标 open 游标名。
3.从游标中提取数据 fetch 游标名 into 标量(需配合循环使用)。
4.关闭游标 close 游标名称。
注意:
1.变量名的个数必须与声明游标时使用的select语句结果集中的字段个数保持一致
2.fetch 在执行过程中如果无法提取数据会产生 “ERROR 1329(0200):Nodata to FETCH”,这样我们可以自定义1329错误来结束遍历。
create PROCEDURE pro_students() BEGIN declare s_age int ; declare s_no varchar(50); declare DONE INT DEFAULT 0; declare cur CURSOR for select age,s_id from students; DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET DONE=1; open cur; fetch cur into s_age,s_no; repeat SET s_age = s_age+1; select s_age; update students s set s.age = s_age where s.s_id=s_no; fetch cur into s_age,s_no; UNTIL DONE END REPEAT; close cur; end; CALL pro_students();
相关文章推荐
- 初学mysql(十)-数据库之存储过程、函数与游标-自定义函数和流程控制(下)
- 存储过程/游标/mysql 函数
- mysql 自定义函数与自定义存储过程的调用方法
- MySQL自定义函数与存储过程
- mysql高级语法:变量声明, 游标, 函数, 存储过程, 循环体, 触发器
- 用游标遍历某台服务器下所有的数据库中 汲及到某个关键词的 所有存储过程及自定义函数
- (9)mysql中的存储过程和自定义函数
- MySQL存储过程和函数以及游标使用详解
- mysql的存储过程与自定义函数
- MSSQL 和 Mysql 切割字符串 自定义函数与存储过程
- MYSQL 存储过程与自定义函数的区别
- MSSQL 和 Mysql 切割字符串 自定义函数与存储过程
- mysql创建自定义函数与存储过程
- mysql系列:存储过程与自定义函数
- mysql存储过程和函数(三)——存储过程和自定义函数示例,大批量测试数据的插入
- MySQL存储过程和自定义函数、Navicat for mysql、创建存储过程和函数、调用存储过程和函数的区别
- MySQL存储过程和自定义函数、Navicat、创建存储过程和函数、调用存储过程和函数、三种方式、In和Out类型参数、
- 初学mysql(九)-数据库之存储过程、函数与游标(上)
- 初探mysql的存储过程和函数-----自定义存储过程和函数
- 深入mysql创建自定义函数与存储过程的详解