一、存储过程补充
(一)流程控制语句
-- 创建存储过程,输入一个数字,如果该数字等于0,输出星期天,数字等于1,输出星期一,以此类推,否则输出无效日期
create procedure ifDemo(in num int)
begin
if num = 0 then
select '星期天';
elseif num = 1 then
select '星期一';
elseif num = 2 then
select '星期二';
elseif num = 3 then
select '星期三';
else
select '无效日期';
end if;
end
call ifDemo(7788)
(二)条件控制语句
-- 创建存储过程,输入一个数字,如果该数字大于0,则输出正数,如果该数字小于0,则输出负数,否则输出不是正数也不是负数
create procedure caseDemo(in num int)
begin
case -- 条件开始
when num > 0 then
select '正数';
when num < 0 then
select '负数';
else
select '不是正数也不是负数';
end case; -- 条件结束
end
call caseDemo(-1)
-- 删除存储过程
drop procedure 存储过程名
eg:
drop procedure ifDemo;
-- 查看存储过程
show create procedure 存储过程名;
(三)循环语句
-- 创建存储过程,实现输入一个数字num,循环10次,每循环一次,num加1,并且将结果累加,最后将结果返回
create procedure whileDemo(in num int,out sum int)
begin
declare count int;
set sum = 0;
set count = 1;
while count <= 10 do -- 循环开始
set count=count+1;
set num=num+1;
set sum=num+sum;
end while; -- 循环结束
select sum;
end
drop procedure whileDemo;
call whileDemo(1,@sum)
练习:
创建存储过程,输入一个字符,将该字符进行拼接,循环至字符串的长度大于
10
,并将结果返回
-- 创建存储过程,实现输入一个数字num,循环至num大于等于,每循环一次,num加1,并且将结果累加,最后将结果返回
create procedure whileDemo(in num int,out sum int)
begin
set sum = 0;
while num <= 10 do -- 循环开始
set num=num+1;
set sum=num+sum;
end while; -- 循环结束
select sum;
end
drop procedure doWhileDemo;
call whileDemo(11,@sum)
-- 方式二
create procedure doWhileDemo(in num int)
begin
declare sum int;
set sum = 0;
repeat -- 循环开始
set num = num + 1; -- 12
set sum = num + sum; -- 12
until num > 10
end repeat; -- 循环结束
select sum;
end
call doWhileDemo(11)
二、mysql备份
备份就是为了防止原数据丢失,保证数据的安全。当数据库因为某些原因造成部分或者全部数据丢失后,备份文件可以帮我们找回丢失的数据。因此,数据备份是很重要的工作。
常见数据库备份的应用场景如下:
(一)数据丢失应用场景:
1.人为操作失误造成某些数据被误操作
2.软件 BUG
造成部分数据或全部数据丢失
3.硬件故障造成数据库部分数据或全部数据丢失
4.安全漏洞被入侵数据恶意破坏
(二)非数据丢失应用场景:
1.特殊应用场景下基于时间点的数据恢复
2.开发测试环境数据库搭建
3.相同数据库的新环境搭建
4.数据库或者数据迁移
方式一:
-- 在dos命令窗口实现
-- 备份
mysqldump -u用户名 -p密码 库名>存储位置的sql文件
-- 恢复
mysql -u用户名 -p密码 库名<存储位置的sql文件
方式二:
在Navicat中鼠标右键选择
转储SQL文件
进行备份,选择运行SQL文件进行恢复。
三、表与表之间的关系
1.一对一关系:比如用户表和用户详情表
2.一对多关系:比如员工表和部门表
3.多对多关系
:
比如学生表和课程表
-- 一对一关系连接查询
select * from user_info ui inner join user_deatil ud on ui.detail_id =
ud.detail_id
-- 一对多关系连接查询
select * from emp e left join dept d on e.deptno = d.deptno
-- 多对多关系连接查询(在此借助新创建的中间表将两表进行关联)
select * from student s inner join stu_class sc on s.id = sc.student_id
inner join class c on c.id = sc.class_id