MySQL分支和循环结构方式

 更新时间:2024年10月25日 08:39:07   作者: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);

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • mysql5.5 master-slave(Replication)配置方法

    mysql5.5 master-slave(Replication)配置方法

    mysql5.5 master-slave(Replication)配置方法,需要的朋友可以参考下。
    2011-08-08
  • mysql命令行脚本执行操作示例

    mysql命令行脚本执行操作示例

    这篇文章主要介绍了mysql命令行脚本执行操作,结合实例形式分析了MySQL命令行操作相关的登入登出、创建删除、增删改查等操作技巧,需要的朋友可以参考下
    2019-11-11
  • VMWare linux mysql 5.7.13安装配置教程

    VMWare linux mysql 5.7.13安装配置教程

    这篇文章主要为大家详细介绍了VMWare linux mysql 5.7.13安装配置教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-05-05
  • MySQL如何为字段添加默认时间浅析

    MySQL如何为字段添加默认时间浅析

    这篇文章主要给大家介绍了关于MySQL如何为字段添加默认时间的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者使用MySQL具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-10-10
  • mac下安装mysql忘记密码的修改方法

    mac下安装mysql忘记密码的修改方法

    这篇文章主要介绍了mac下安装mysql忘记密码的修改方法,需要的朋友可以参考下
    2017-06-06
  • MYSQL加密和压缩函数详解以及实战(附示例)

    MYSQL加密和压缩函数详解以及实战(附示例)

    这篇文章主要给大家介绍了关于MYSQL加密和压缩函数详解以及实战的相关资料,加密函数主要用来对数据进行加密和界面处理,以保证某些重要数据不被别人获取,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2023-12-12
  • Mysql中的Btree与Hash索引比较

    Mysql中的Btree与Hash索引比较

    这篇文章主要介绍了Mysql中的Btree与Hash索引比较,本文起讲解了B-Tree 索引特征、Hash 索引特征等内容,需要的朋友可以参考下
    2015-03-03
  • MySQL GTID全面总结

    MySQL GTID全面总结

    这篇文章主要介绍了MySQL GTID的相关资料,帮助大家更好的理解和学习使用MySQL数据库,感兴趣的朋友可以了解下
    2021-03-03
  • mysql中的utf8与utf8mb4存储及区别

    mysql中的utf8与utf8mb4存储及区别

    本文主要介绍了mysql中的utf8与utf8mb4存储及区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-02-02
  • 提高MySQL中数据装载效率

    提高MySQL中数据装载效率

    很多时候关心的是优化SELECT 查询,因为它们是最常用的查询,而且确定怎样优化它们并不总是直截了当。
    2009-11-11

最新评论