MySQL数据库---Day 05

文章介绍了MySQL中的存储过程,包括流程控制语句如IF...ELSE和CASE语句,以及循环语句如WHILE和REPEAT。同时,讲解了数据库备份的重要性,列举了备份的应用场景,并提供了两种备份方法。最后,讨论了数据库表间的一对一、一对多和多对多关系及对应的查询示例。
摘要由CSDN通过智能技术生成

一、存储过程补充

(一)流程控制语句

-- 创建存储过程,输入一个数字,如果该数字等于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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值