mysql -- 自定义函数及循环结构
程序员文章站
2022-04-17 19:49:41
...
和存储过程类似,区别在于存储过程可以有0个或多个返回,但是函数只能有唯一一个返回值 一般而言,存储过程适合批量插入,批量删除,增删改;函数则用于处理数据,查询某个值。
创建
create function 函数名( 参数名 参数类型 ) returns 返回类型;
begin
函数体;
end
函数体肯定会有return 语句,如果没有会报错。
调用
select 函数名(参数列表);
示例
比方有员工表employees
id | name |
---|---|
1 | jack |
… | … |
要统计员工个数则可使用以下自定义函数:
# 创建
create function fun() returns int
begin
declare temp int defualt 0;
select count(*) into temp
from employees;
return temp;
end;
# 调用
select func();
查看
show create function 函数名;
存储过程可在mysql数据库的proc表里查看,这个表里保存了这个数据库中保存的存储过程和函数,以type字段作为区分二者的标志。
删除
drop function 函数名
和存储过程一样函数一般也很少做修改,若要修改则删掉之后再创建。
循环结构
mysql中,循环有while do , loop, repeat until, 循环体里的跳转语句有 iterate ,类似于continue,开始下一轮循环, leave,类似于break 结束循环体。
while do
语法:
[标签:] while 条件 do # [] 表示可选
循环体...
end while [标签];
示例: 批量插入,根据次数插入多次数条到某个表
中, 如果次数大于20则停止:
delimiter $
create procedure pro_while( in insertCount int )
begin
declare i int default 1;
a: while i <= insertCount do
if i > 20 then leave a;
end if;
#插入语句;
set i = i +1;
end while a;
end $;
delimiter ;
loop
语法:
[标签:] loop
循环体;
end loop [标签];
loop 没有条件判定
,若要结束循环体只能搭配leave 标签;
使用,否则就是死循环。
repeat until
语法
[标签:] repeat
循环体
until 满足结束循环的条件
end repeat [标签];
repeat 必然
会执行一次循环体,而,其条件 是 满足该条件之后就结束循环体,与while 满足条件则执行循环体恰恰相反。
推荐阅读
-
JQuery each()函数如何优化循环DOM结构的性能
-
MySQL基础篇(03):系统和自定义函数总结,触发器使用详解
-
mysql From_unixtime及UNIX_TIMESTAMP及DATE_FORMAT日期函数
-
MySQL通过自定义函数实现递归查询父级ID或者子级ID
-
MYSQL自定义函数判断是否正整数的实例代码
-
荐 【MySQL系列7】InnoDB引擎存储结构及InnoDB特性Change Buffer和Double Writer分析
-
WordPress中查询文章的循环Loop结构及用法分析
-
mysql自定义函数原理与用法实例分析
-
MYSQL存储过程和函数的区别及操作分析
-
自定义标签的开发及使用自定义标签实现迭代foreach循环