本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了关于存储过程的相关内容,包括了存储过程传参、流程控制、以及游标和异常处理等问题,下面一起来看一下,希望对大家有帮助。
推荐学习:mysql视频教程
mysql5.0版本开始支持存储过程,存储过程就是一组sql语句集,功能强大,可以实现一些比较复杂的逻辑功能,类似于java语言中的方法,存储过就是数据库sql与层层面的代码封装与重用
1.有输入输出参数,可以声明变量,有if/else/case/while等控制语句,通过编写存储过程,可以实现复杂的逻辑功能
2.函数的普通特性:模块化,封装,代码复用
3.速度快,只有首次执行需要经过编译和优化步骤,后续被调用可以直接执行,省去以上步骤
格式创建存储过程
-- 创建存储过程delimiter $$create procedure proc01()begin select empno,ename from emp;end $$delimiter ;-- 调用存储过程call proc01;
定义变量局部变量用户自定义,在begin/end块中有效
delimiter $$create procedure proc02()begin declare var_name01 varchar(20) default 'aaa'; -- 声明/定义变量 set var_naem01 = 'zhangsan'; -- 给变量赋值 select var_name01; -- 输出变量的值end $$dilimiter ;call proc02();
用户变量用户自定义,当前会话(连接)有效.类比java的成员变量
delimiter $$create procedure proc04()begin set @var_name01 = 'beijing'; select @var_name01;end $$dilimiter ;call proc04();select @var_name01; -- 外部也是可以使用用户变量
系统变量1.系统变量有分为全局变量与会话变量
2.全局变量在mysql启动的时候由服务器自动将他的初始化为默认值,这些默认值可以通过更改my.ini这个文件来更改
3.会话变量在每次建立一个新的连接的时候,由mysql来初始化,mysql会将当前所有全局变量的值复制一份,来作为会话变量
4.也就是说,如果在建立会话以后,没有手动更改过会话变量与全局变量的值,那所有这些变量的值都是一样的
5.全局变量与会话变量的区别在于,对全局变量的修改会影响整个服务器,但是对会话变量的修改,只会影响到当前的会话(也就是当前的数据库连接)
6.有些系统变量的值是可以利用语句来动态进行更改的,但是有些系统变量的值缺是只读的,对于那些可以更改的系统变量,我们可以利用set语句进行更改
系统变量-全局变量
由系统系统,在整个数据库中有效
存储过程存储过程传参-inin表示传入的参数,可以传入数值或者变量,即使传入变量,并不会改变变量的值,可以内部更改,仅仅作用在函数范围内
delimiter $$create procedure proc06(in param_empno int)begin select*from emp where empno = param_empnoend $$delimiter ;call proc06(1001);
多个参数传参
存储过程传参-outout表示从存储过程内部传值给调用者
存储过程传参-inoutinout表示从外部传入的参数经过修改后可以返回的变量,既可以使用传入变量的值也可以修改变量的值(即使函数执行完)
流程控制流程控制-判断if语句包含多个条件判断,根据结果为ture和false执行语句,与编程语言中的if、else if、else语法类似,其语法格式如下
-- 存储过程-if-- 案例1-- 输入学生的成绩,来判断成绩的级别/*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>=60 and 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 ;set @score=55;call proc_12_if(@score)
-- 输入员工的名字,判断工资的情况/*sal<10000 :适用薪资sal>=10000 and sal<20000 :转正薪资sal>=20000 :元老薪资*/delimiter $$create procedure proc_13_if(in in_ename varchar)begin declare var_sal decimal(7,2); -- 定义局部变量,7个长度,2个小数 declare result varchar(20); select sal into var_sal from emp where ename=in_eanme; -- 将值赋给局部变量 if var_sal 0 */ declare continue handler for 1329 set flag=0 ; -- 打开游标 open my_cursor; -- 通过游标获取值-- fetch my_cursor into var_empno,var_ename,var_sal;-- select var_empno,var_ename,var_sal; -- 注意:以上两句只可以获取一个数据,因为游标是一次一行,所以采用循环 label:loop fetch my_cursor into var_empno,var_ename,var_sal; -- 判断flag的值如果为1则执行,否则不执行 if flag =1 then select var_empno,var_ename,var_sal; else leave label; end if; end loop label; -- 关闭游标 close my_cursor;end$$delimiter ;call proc19_cursor('销售部');
推荐学习:mysql视频教程
以上就是一文掌握mysql的存储过程的详细内容。