存储过程和函数:类似于java中的方法

好处:

1、提高代码的重用性
2、简化操作

存储过程

含义:

一组预先编译好的SQL语句的集合,理解成批处理语句
1、提高代码的重用性
2、简化操作
3、减少了编译次数并且减少了和数据库服务器的连接次数,提高了效率

一、创建语法

  1. CREATE PROCEDURE 存储过程名(参数列表)
  2. BEGIN
  3. 存储过程体(一组合法的SQL语句)
  4. END

注意:

1、参数列表包含三部分

参数模式 参数名 参数类型

举例:

in stuname varchar(20)

参数模式:

in:该参数可以作为输入,也就是该参数需要调用方传入值
out:该参数可以作为输出,也就是该参数可以作为返回值
inout:该参数既可以作为输入又可以作为输出,也就是该参数既需要传入值,又可以返回值

2、如果存储过程体仅仅只有一句话,begin end可以省略

存储过程体中的每条sql语句的结尾要求必须加分号。
存储过程的结尾可以使用 delimiter 重新设置

语法:

delimiter 结束标记

案例:

delimiter $

二、调用语法

CALL 存储过程名(实参列表);

案例演示

1.空参列表

案例:插入到admin表中五条记录

#################需要一起执行,不可分割########################
DELIMITER $
CREATE PROCEDURE myp3()
BEGIN
    INSERT INTO admin(username,`password`) 
    VALUES('john1','0000'),('lily','0000'),('rose','0000'),('jack','0000'),('tom','0000');
END $
#调用
call myp3() $
###############################
select * from admin;
DELIMITER $
CREATE PROCEDURE myp()
BEGIN
    INSERT INTO admin(username,`password`) 
    VALUES('john1','0000'),('lily','0000'),('rose','0000'),('jack','0000'),('tom','0000');
END $
DELIMITER ;
call myp();
######################################
select * from admin;

2.创建带in模式参数的存储过程

案例1:创建存储过程实现 根据女神名,查询对应的男神信息

DELIMITER $
CREATE PROCEDURE myp2(IN beautyName VARCHAR(20))
BEGIN
    SELECT bo.*
    FROM boys bo
    RIGHT JOIN beauty b ON bo.id = b.boyfriend_id
    WHERE b.name=beautyName;
END $
CALL myp2('柳岩')$

案例2 :创建存储过程实现,用户是否登录成功

delimiter $
create procedure myp4(in username varchar(20),in password varchar(20))
begin
    declare result int default 0;#声明并初始化
    select count(*) into result from admin where admin.username=username
    and admin.password=password;#赋值
    select if(result>0,'成功','失败');#使用
end $
######################################
call myp4('john','8888')

3.创建out 模式参数的存储过程

案例1:根据输入的女神名,返回对应的男神名

delimiter $
create procedure myp6(in beatutyName varchar(20),out boyName varchar(20))
begin
    select bo.boyname into boyName from boys bo right join beauty b on b.boyfriend_id=bo.id
    where b.name=beatutyName;
end $    
delimiter ;

call myp6('小昭',@boyName);

案例2:根据输入的女神名,返回对应的男神名和魅力值

delimiter $
create procedure myp8(in beautyName varchar(20),out boyName varchar(20),out usercp int)
begin 
    select boys.boyname,boys.usercp into boyName,usercp from boys 
    right join beauty b on b.boyfriend_id=boys.id
    where b.name=beautyName;
    select boyName,usercp;#使用
end $
delimiter ;

call myp8('小昭',@name,@cp);
select @name,@cp;

4.创建带inout模式参数的存储过程

案例1:传入a和b两个值,最终a和b都翻倍并返回

create procedure myp(inout a int,inout b int)
begin
    set a=a*2;
    set b=b*2;
end 
#调用
set @m=10;
set @n=20;
call myp(@m,@n);
select @m,@n;

三、删除存储过程

语法:

drop procedure 存储过程名

drop procedure myp;
drop procedure myp4,myp6;#x

四、查看存储过程的信息

desc myp4;#x
show create procedure myp4;
select @@sql_mode; #定义MySQL对约束的响应行为

函数

含义:

一组预先编译好的SQL语句的集合,理解成批处理语句
1、提高代码的重用性
2、简化操作
3、减少了编译次数并且减少了和数据库服务器的连接次数,提高了效率

区别:

存储过程:可以有0个返回,也可以有多个返回,适合做批量插入、批量更新
函数:有且仅有1 个返回,适合做处理数据后返回一个结果

一、创建语法

CREATE FUNCTION 函数名(参数列表) RETURNS 返回类型
BEGIN
    函数体
END

注意:
1.参数列表 包含两部分:
参数名 参数类型
2.函数体:肯定会有return语句,如果没有会报错
如果return语句没有放在函数体的最后也不报错,但不建议
return 值;
3.函数体中仅有一句话,则可以省略begin end
4.使用 delimiter语句设置结束标记

二、调用语法

SELECT 函数名(参数列表)

案例演示

1.无参有返回

案例:返回公司的员工个数

create function myf1() returns int
begin
    declare c int default 0;#定义局部变量
    select count(1) into c from employees;#赋值
    return c;
end $

select myf1()$

可能出现的问题:
image.png

set global log_bin_trust_function_creators=TRUE;

2.有参有返回

案例1:根据员工名,返回它的工资

create function myf2(empName varchar(20)) returns double
begin
    set @sal=0;#定义用户变量
    select salary into @sal #赋值
    from employees
    where last_name=empName;
    return @sal;
end
select myf2('K_ing');

案例2:根据部门名,返回该部门的平均工资

create function myf3(deptName varchar(20)) returns double
begin
    declare sal double;
    select avg(salary) into sal from employees e
    join departments d on e.department_id=d.department_id
    where d.department_name=deptName;
    return sal;
end
select myf3('IT');

三、查看函数

show create function myf3;

四、删除函数

drop function myf3;

案例

一、创建函数,实现传入两个float,返回二者之和

create function test_fun1(num1 float,num2 float)returns float
begin
    declare sum float default 0;
    set sum=num1+num2;
    return sum;
end

select test_fun1(1,2);