MySQL分支和循环结构方式
作者:Carver0808
在MySQL中,IF函数用于根据条件返回不同的值,类似于Java的三目运算符,CASE语句则提供了两种形式:简单CASE函数和搜索CASE函数,分别类似于Java中的switch-case结构和多重if判断,这些控制流函数在数据库查询和数据处理中非常有用,可以实现复杂的逻辑判断
一、if函数
在mysql中if()函数的用法类似于java中的三目表达式,其用处也比较多,
具体语法如下:
IF(expr1,expr2,expr3),如果expr1的值为true,则返回expr2的值,如果expr1的值为false,则返回expr3的值。注意:if函数可以用在任何位置。
例如:
select * ,if(role_id=1,‘管理员’,‘普通用户’) as role from user_p;当role_id为1时,返回管理员,role_id非1返回普通用户。
二、case语句
1、情景一(case函数)
类似于Java总的switch-case结构,代码和运行截图如下:
语法:
- case 表达式
- when 值1 then 结果1或语句1(如果是语句,需要加分号)
- when 值2 then 结果2或语句2(如果是语句,需要加分号)
- …
- else 结果n或语句n(如果是语句,需要加分号)
- end 【case】(如果是放在begin end中需要加上case,如果放在select后面不需要)
select *, case role_id when 1 then "管理员" when 2 then "普通用户" else "游客" end as role from user_p;
2、情景二(case搜索函数)
类似于多重if,可以用在任何位置。代码和运行截图如下:
语法:
- case
- when 条件1 then 结果1或语句1(如果是语句,需要加分号)
- when 条件2 then 结果2或语句2(如果是语句,需要加分号)
- …
- else 结果n或语句n(如果是语句,需要加分号)
- end 【case】(如果是放在begin end中需要加上case,如果放在select后面不需要)
select *,case when age <19 then "少年" when age <30 then "青年" when age >30 and age <50 then "中年" else "老年" end "状态" from info;
三、if elseif语句
注意:只能用在begin end中
- 语法:
- if 情况1 then 语句1;
- elseif 情况2 then 语句2;
- …
- else 语句n;
- end if;
#定义分号 DELIMITER $$ # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # CREATE FUNCTION age_status(age int) RETURNS varchar(20) BEGIN DECLARE status varchar(20) DEFAULT "老年"; IF age < 19 THEN SET status ="少年"; ELSEIF age <30 THEN SET status ="青年"; ELSEIF 30<age<50 THEN SET status ="中年"; ELSE SET status ="老年"; END IF; RETURN status; END $$ # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # #重新定义分号 DELIMITER ; # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # select age_status(45);
四、循环
DELIMITER $$ # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # CREATE FUNCTION insertUser(num INT) RETURNS varchar(15) BEGIN DECLARE i INT DEFAULT(1); while i<= num DO INSERT INTO info(name,sex,classname,age) VALUES (CONCAT("name",i),CONCAT("sex",i),CONCAT("classname",i),i); SET i=i+1; END WHILE; RETURN "success"; END $$ # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # DELIMITER ; # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # select insertUser(5);
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。