MySQL 存储过程的简单使用
作者:@nnngu
本文为作者原创,转载请注明出处:https://www.cnblogs.com/nnngu/p/8463399.html
首先创建一张 students 表
SQL脚本如下:
1
2
3
4
5
6
7
8
9
10
11
create table students(
id int primary key auto_increment,
age int,
name varchar(20),
city varchar(20)
) character set utf8;
insert into students values(null, 22, 'lisa', '杭州');
insert into students values(null, 16, 'rock', '上海');
insert into students values(null, 20, 'jack', '深圳');
insert into students values(null, 21, 'rose', '北京');
不带参数的存储过程
1
2
3
4
5
6
7
8
9
-- 查询学生个数
drop procedure if exists select_students_count;
delimiter ;; -- 替换分隔符
create procedure select_students_count()
begin
select count(id) from students;
end ;;
delimiter ;
执行存储过程:
call select_students_count();
带参数的存储过程
1
2
3
4
5
6
7
-- 根据城市查询总数
delimiter ;;
create procedure select_students_by_city_count(in _city varchar(255))
begin
select count(id) from students where city = _city;
end;;
delimiter ;
执行存储过程:
call select_students_by_city_count('上海');
带有输出参数的存储过程
MySQL 支持 in (传递给存储过程),out (从存储过程传出) 和 inout (对存储过程传入和传出) 类型的参数。存储过程的代码位于 begin 和 end 语句内,它们是一系列 select 语句,用来检索值,然后保存到相应的变量 (通过 into 关键字)
1
2
3
4
5
6
7
8
9
10
11
-- 根据姓名查询学生信息,返回学生的城市
delimiter ;;
create procedure select_students_by_name(
in _name varchar(255),
out _city varchar(255), -- 输出参数
inout _age int(11)
)
begin
select city from students where name = _name and age = _age into _city;
end ;;
delimiter ;
执行存储过程:
1
2
3
4
set @_age = 20;
set @_name = 'jack';
call select_students_by_name(@_name, @_city, @_age);
select @_city as city, @_age as age;
带有通配符的存储过程
1
2
3
4
5
6
7
8
delimiter ;;
create procedure select_students_by_likename(
in _likename varchar(255)
)
begin
select * from students where name like _likename;
end ;;
delimiter ;
执行存储过程:
1
2
call select_students_by_likename('%s%');
call select_students_by_likename('%j%');
使用存储过程进行增加、修改、删除
增加
1
2
3
4
5
6
7
8
9
10
11
delimiter ;;
create procedure insert_student(
_id int,
_name varchar(255),
_age int,
_city varchar(255)
)
begin
insert into students(id,name,age,city) values(_id,_name,_age,_city);
end ;;
delimiter ;
执行存储过程:
call insert_student(5, '张三', 19, '上海');
执行完后,表中多了一条数据,如下图:
修改
1
2
3
4
5
6
7
8
9
10
11
delimiter ;;
create procedure update_student(
_id int,
_name varchar(255),
_age int,
_city varchar(255)
)
begin
update students set name = _name, age = _age, city = _city where id = _id;
end ;;
delimiter ;
执行存储过程:
call update_student(5, 'amy', 22, '杭州');
删除
1
2
3
4
5
6
7
8
delimiter ;;
create procedure delete_student_by_id(
_id int
)
begin
delete from students where id=_id;
end ;;
delimiter ;
执行存储过程:
call delete_student_by_id(5);
students 表中 id 为5的那条记录成功删除。如下图:
查询存储过程
查询所有的存储过程:
select name from mysql.proc where db='数据库名';
查询某个存储过程:
show create procedure 存储过程名;
分类:
MySQL
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core GC压缩(compact_phase)底层原理浅谈
· 现代计算机视觉入门之:什么是图片特征编码
· .NET 9 new features-C#13新的锁类型和语义
· Linux系统下SQL Server数据库镜像配置全流程详解
· 现代计算机视觉入门之:什么是视频
· 【译】我们最喜欢的2024年的 Visual Studio 新功能
· 个人数据保全计划:从印象笔记迁移到joplin
· Vue3.5常用特性整理
· 重拾 SSH:从基础到安全加固
· 为什么UNIX使用init进程启动其他进程?