存储过程和函数:类似于java中的方法
好处:
存储过程
含义:
一组预先编译好的SQL语句的集合,理解成批处理语句
1、提高代码的重用性
2、简化操作
3、减少了编译次数并且减少了和数据库服务器的连接次数,提高了效率
一、创建语法
CREATE PROCEDURE 存储过程名(参数列表)BEGIN存储过程体(一组合法的SQL语句)END
注意:
1、参数列表包含三部分
举例:
参数模式:
in:该参数可以作为输入,也就是该参数需要调用方传入值
out:该参数可以作为输出,也就是该参数可以作为返回值
inout:该参数既可以作为输入又可以作为输出,也就是该参数既需要传入值,又可以返回值
2、如果存储过程体仅仅只有一句话,begin end可以省略
存储过程体中的每条sql语句的结尾要求必须加分号。
存储过程的结尾可以使用 delimiter 重新设置
语法:
案例:
二、调用语法
案例演示
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语句设置结束标记
二、调用语法
案例演示
1.无参有返回
案例:返回公司的员工个数
create function myf1() returns int
begin
declare c int default 0;#定义局部变量
select count(1) into c from employees;#赋值
return c;
end $
select myf1()$
可能出现的问题:
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);
