什么是存储过程:
类似于java中的方法,python中的函数。
使用存储过程的好处:
1、提高代码的重用性;
2、简化操作;
3、减少了编译次数,并且减少了和数据库服务器的连接次数,提高了效率。注意:平时每执行一句sql语句,就会连接mysql服务器一次;
存储过程的含义:
一组预先编译好的SQL语句的集合。
create procedure 存储过程名(参数列表)
begin
存储过程体(一组合法有效的sql语句)
end
参数模式 参数名 参数类型
例如:in stuname varchar(20)
in:该参数可以作为输入,也就是该参数,需要调用方传入值。
out:该参数可以作为输出,也就是该参数,可以作为返回值。
inout:该参数既可以作为输入又可以作为输出,也就是该参数既需要传入值,又可以返回值。
Ⅰ 存储过程体中的每条sql语句的结尾,要求必须加分号。
Ⅱ 存储过程的结尾,可以使用delimiter重新设置,否则都用";"会造成混淆。
语法:delimiter 结束标记
例如:delimiter $ -- 表示以$作为结尾符号。
call 存储过程名(实参列表);
"存储过程的整个执行过程,最好在CMD窗口中执行"
-- 创建一个存储过程
delimiter $
create procedure myp()
begin
insert into admin(username,`password`)
values ("tom","1111"),("jerry","2222"),
("jalen","3333"),("rose","4444"),("tonny","5555");
end $
-- 调用存储过程
call myp()$
-- 查看结果。
select * from admin$
结果如下:
-- 创建一个存储过程
delimiter $
create procedure myp2(in num int)
begin
select e.ename,d.dname
from emp e
left join dept d on e.deptno=d.deptno
where e.deptno=num;
end $
-- 调用存储过程
call myp2(10)$
结果如下:
操作如下:
-- 创建一个存储过程
delimiter $
create procedure myp3(in username varchar(10),password varchar(10))
begin
declare result int;
select count(*) into result
from admin ad
where ad.username=username
and ad.password=password;
select if(count(*) > 0,"登陆成功","登陆失败") 登陆状态;
end $
-- 调用存储过程
call myp3('john','8888');
结果如下:
-- 创建一个存储过程
delimiter $
create procedure myp4(in beautyName varchar(20),out boyName varchar(20))
begin
select b.boyName into boyName
from beauty left join boys b
on beauty.boyfriend_id=b.id
where beauty.name=beautyName;
end $
-- 调用
# 重新定义一个变量@boyname接收返回值boyName。
call myp4("赵敏",@boyname)$
select @boyname$
call myp4("柳岩",@boyname)$
select @boyname$
结果如下:
-- 创建一个存储过程
delimiter $
create procedure myp5(in beautyName varchar(20),out boyName varchar(20),out userCP int)
begin
select b.boyName,b.userCP into boyName,userCP
from beauty left join boys b
on beauty.boyfriend_id=b.id
where beauty.name=beautyName;
end $
-- 调用
# 重新定义一个变量@boyname接收返回值boyName。
call myp5("赵敏",@boyname,@usercp)$
select @boyname,@usercp$
call myp5("柳岩",@boyname,@usercp)$
select @boyname,@usercp$
结果如下:
-- 创建一个存储过程
delimiter $
create procedure myp6(inout a int ,inout b int)
begin
-- 局部变量不用加@符号。
set a=a*2;
set b=b*2;
end $
-- 调用
-- 特别注意调用这一块儿。
set @m=10$
set @n=20$
call myp6(@m,@n)$
select @m,@n$
结果如下:
-- 创建一个存储过程
delimiter $
create procedure pro1(in username varchar(20),in userpwd varchar(20))
begin
insert into admin(username,`password`)
values (username,userpwd);
end $
-- 调用存储过程
call pro1("鲁智深","123abc")$
select * from admin$
结果如下:
-- 创建一个存储过程
delimiter $
create procedure pro2(in id int,out beautyName varchar(20),out beautyPhone varchar(20))
begin
select beauty.name,beauty.phone into beautyName,beautyPhone
from beauty
where beauty.id=id;
end $
-- 调用存储过程
call pro2(2,@beautyname,@beautyphone)$
select @beautyname,@beautyphone$
call pro2(3,@beautyname,@beautyphone)$
select @beautyname,@beautyphone$
结果如下:
-- 创建一个存储过程
delimiter $
create procedure pro3(in borndate1 datetime,in borndate2 datetime,out result int)
begin
select datediff(borndate1,borndate2) into result;
end $
-- 调用存储过程
call pro3("1993-8-12",now(),@result)$
select @result$
结果如下:
drop procedure 存储过程名;
1)创建存储过程或函数实现传入女神名称,返回:女神AND男神,格式的字符串
如传入:小昭
返回:小昭AND张无忌
2)创建存储过程或函数,根据传入的条目数和起始索引,查询beauty表的记录。
delimiter $
create procedure test1(in beautyname varchar(20))
begin
select concat(beauty.name,"AND",boys.boyName)
from beauty left join boys
on beauty.boyfriend_id=boys.id
where beauty.name=beautyname;
end $
call test1("柳岩")$
call test1("赵敏")$
结果如下:
delimiter $
create procedure test2(in startIndex int,in length int)
begin
select *
from beauty
limit startIndex,length;
end $
-- 每页显示3条记录
-- 显示第2页
call test2(3,3)$
-- 显示第3页
call test2(6,3)$
结果如下: