开发者社区> 王小王-123> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

MySQL的存储过程——流程控制-if判断

简介: MySQL的存储过程——流程控制-if判断
+关注继续查看

IF语句包含多个条件判断,根据结果为TRUE、FALSE执行语句,与编程语言中的if、else if、else语法类似,其语法格式如下:


-- 语法
if search_condition_1 then statement_list_1
    [elseif search_condition_2 then statement_list_2] ...
    [else statement_list_n]
end if

学生成绩等级存储过程

-- 输入学生的成绩,来判断成绩的级别:
/*
  score < 60 :不及格
  score >= 60  , score <80 :及格
    score >= 80 , score < 90 :良好
    score >= 90 , score <= 100 :优秀
    score > 100 :成绩错误
*/
delimiter  $$
create procedure proc_12_if(in score int)
begin
  if score < 60 
      then
          select '不及格';
    elseif  score < 80
      then

         select '及格' ;

   elseif score >= 80 and score < 90

      then

          select '良好';

 elseif score >= 90 and score <= 100

      then

          select '优秀';

    else

      select '成绩错误';

 end if;

end $$

delimiter  ;

call proc_12_if(120)

通过这个我们可以总结出这个流程,写流程控制语句的时候,首先注意存储语法的具体格式是什么,然后需要记住每一次的判断之后结束语句(if   then  ;)需要加分号,然后最后需要以end if结尾,也需要加分号。


-- 输入员工的名字,判断工资的情况。
delimiter $$
create procedure proc12_if(in in_ename varchar(50))
begin
    declare result varchar(20);
    declare var_sal decimal(7,2);
        select sal into  var_sal from emp where ename = in_ename;
    if var_sal < 10000

       then set result = '试用薪资';

   elseif var_sal < 30000

       then set result = '转正薪资';

   else

       set result = '元老薪资';

   end if;

   select result;

end$$

delimiter ;

call proc12_if('庞统');

这里输入了一个参数,利用这个参数在内部获取到它的薪水,然后把这个薪水赋给一个变量,所以此时就需要定义局部变量了,采用declare 然后into 语法,最后需要显示出级别,那么又不想要在里面写select,那么就直接设置变量了,这样就可以使得编程结构化,那么我们就需要重新定义一个变量,用于接收这个级别,每一次就是使用set设置,最后select 该变量就可以了。


其实这些存储过程到底可以实现什么功能,为什么要这样,在做软件或者系统开发的时候,肯定会有基于用户的输入和查询,那么将这些封装为一个存储过程,就可以保证结构和开发的高效有序。



image.png


版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
MySQL的存储过程——流程控制-case
MySQL的存储过程——流程控制-case
12 0
MySQL的存储过程——流程控制-case
MySQL的存储过程——流程控制-case
13 0
mysql存储过程(一)
mysql存储过程(一)
37 0
【MySQL】存储过程
【MySQL】存储过程
32 0
MYSQL存储过程(一)
MYSQL存储过程语法结构:变量及赋值、入参出参、流程控制-判断、流程控制-循环、流程控制-退出、继续循环
147 0
MySQL之存储过程
1、存储过程概念 2、存储过程调用 3、存储过程示例 4、带参数的存储过程 5、while在存储过程中的使用 ...
1235 0
mysql存储过程
此存储过程实例,主要注意 在存储过程中 if 语句的使用,已经如果存在则不添加 not exists的使用, insert into table_name(column1) select column1 from table_name2 where colunm2=’condition1’ and not exists (select 1 from table_na
1061 0
SQL——存储过程
原文:SQL——存储过程 1. 为什么使用存储过程      应用程序通过T-SQL语句到服务器的过程是不安全的。      1) 数据不安全       2)每次提交SQL代码都要经过语法编译后在执行,影响应用程序的运行性能       3) 网络流量大   2. 什么是存储过程         存储过程是SQL语句和控制语句的预编译集合,保存在数据库里,可由应用程序调用执行,而且允许用户声明变量、逻辑控制语句及其他强大的编程功能。
999 0
+关注
王小王-123
快乐代码,精彩人生!
268
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
冬季实战营第三期:MySQL数据库进阶实战
立即下载