MySQL 学习笔记(二):数据库更新、视图和数据控制

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 基础准备:在 school 数据库下建立student、course、sc 三个表:create table student( Sno char(9) primary key, Sname char(20) unique, Ssex char(2), Sage int, S...

基础准备:

在 school 数据库下建立student、course、sc 三个表:

create table student(
  Sno char(9) primary key,
  Sname char(20) unique,
  Ssex char(2),
  Sage int,
  Sdept char(20));

create table Course(
  Cno char(4) primary key,
  Cname char(40),
  Cpno char(4),
  Ccredit int);

create table SC(
  Sno char(9),
  Cno char(4),
  Grade int,
  primary key(Sno,Cno),
  foreign key (sno) references Student(sno),
  foreign key (Cno) references Course(Cno));

insert into  student values ('95001','李勇','',20,'CS');
insert into student values ('95002', '刘晨','',19,'IS');
insert into  student values('95003', '王敏', '',18, 'MA');
insert into student values('95004', '张立', '',19, 'IS');

insert into Course values(1,'数据库', 5,4);
insert into Course values(2, '数学', 3 ,2);
insert into Course values(3, '信息系统', 1, 4);
insert into Course values('4', '操作系统', '6', 3);
insert into Course values('5', ' 数据结构', '7', 4);
insert into Course values('6', '数据处理',  '',  2);
insert into Course values('7',  'PASCAL语言', '6', 4);

insert into SC values('95001', '1', 92);
insert into SC values('95001', '2', 85);
insert into SC values('95001', '3', 88);
insert into SC values('95002', '2', 90);
insert into SC values('95002', '3', 80);

 

(一)数据库更新
1. 在school数据库中,确保表之间已经建立关系,用企业管理器建立数据库的关系图(Diagrams)
2. 在course 表中删除cno=1的记录,有什么结果?
  报错:因为有外键约束。
3. 编辑course表和 sc表之间的关系,添加级联删除相关记录和级更新相关记录

create table SC(
          Sno char(9),
          Cno char(4),
          Grade int,
          primary key(Sno,Cno),
          foreign key (sno) references Student(sno) on delete cascade on update cascade,
          foreign key (Cno) references Course(Cno);

重复2的操作,观察course 表和 sc表的变化,有什么结果,为什么?
  没有报错,成功删除 cno = 1行。

 4. 将course表和sc表的课程号为2的都改为22,如何做?(提示:在Diagrams中编辑course表和 sc表之间的关系,选择级联更新相关记录cascade update related fields)

update sc set cno=22 where cno=2;
update course set cno=22 where cno=2;

5. 在SC表中,
(1)将95002同学的成绩都减少10%

update sc set course=80 where sno=95002;

(2) 课程号为3的改为33

update sc set cno=33 where cno=3;

改不了。不能修改子表,只能修改主表。

6.
(1) 在STUDENT表中插入一条新纪录:  95006   李三   男   21   IS

insert into student (sno, sname, ssex, sage, sdept) values (95006,'李三','',21,'IS');

2)在SC表中插入一条新纪录: 95008       3    80

insert into student (sno, cno, grade) values (95008, 3, 80);

 

出错,因为不能修改子表,只能修改主表。

 

(二)建立新用户和数据控制管理
使用命令行界面:
1.创建用户:

CREATE USER 'username'@'host' IDENTIFIED BY 'password'; 

说明:username - 你将创建的用户名, host - 指定该用户在哪个主机上可以登陆,如果是本地用户可用localhost, 如果想让该用户可以从任意远程主机登陆,可以使用通配符%. password - 该用户的登陆密码,密码可以为空,如果为空则该用户可以不需要密码登陆服务器。

2.授权: 

GRANT privileges ON databasename.tablename TO 'username'@'host' 

说明: privileges - 用户的操作权限,如SELECT , INSERT , UPDATE 等(详细列表见该文最后面).如果要授予所的权限则使用ALL.;databasename - 数据库名,tablename-表名,如果要授予该用户对所有数据库和表的相应操作权限则可用*表示, 如*.*. 

例子:

create user stu1@localhost identified by 'stu1';
grant create view on school.* to stu1@localhost;

当创建过程没问题,提示 Can't find any matching row in the user table
记得刷新一下: flush privileges;

 

3.建立存储过程和函数 建立存储过程sp1

mysql> delimiter $$         #将语句的结束符号从分号;临时改为两个$$(可以是自定义)
mysql> create procedure sp1()    
    -> begin 
    -> grant create view on school.* to stu2@localhost;
    -> grant select,update,insert,delete on school.student to stu2@localhost;
    -> grant select,update,insert,delete on school.course to stu2@localhost;
    -> grant select,update,insert,delete on school.sc to stu2@localhost;
    -> end$$
mysql> delimiter ;        #将语句的结束符号恢复为分号    

建立存储过程sp2

mysql> delimiter $$    #将语句的结束符号从分号;临时改为两个$$(可以是自定义)
mysql> create procedure sp2()
-> begin
-> grant select on school.student to stu1@localhost;
-> grant select on school.course to stu1@localhost;
-> grant select on school.sc to stu1@localhost;
-> grant insert on school.student to stu1@localhost, stu2@localhost;
-> grant update(Ccredit) on course to stu1;
-> end$$

建立存储过程sp3

mysql> delimiter $$        #将语句的结束符号从分号;临时改为两个$$(可以是自定义)
mysql> create procedure sp3()
    -> begin
    -> revoke select on school.student from stu1@localhost;
    -> revoke select on school.course from stu1@localhost;
    -> revoke select on school.sc from stu1@localhost;
    -> end$$
mysql> delimiter ;        #将语句的结束符号恢复为分号    

grant 语句赋予权限,revoke 语句取消权限。

撤销已经赋予给 MySQL 用户权限的权限revoke

revoke all on *.* from dba@localhost;


和grant类似,只需将关键字to换成from,同样可以针对特定用户特定库撤销特定权限。

MySQL 删除存储过程和函数:
基本的语法格式如下:

DROP {PROCEDURE|FUNCTION} sp_name;  

其中,sp_name参数表示存储过程或函数的名称。
删除存储过程test。SQL代码如下:

drop procedure if exists test;

 

执行存储过程sp1(), sp2(), sp3()

call sp1();
call sp2();
call sp3();

 

(三) 视图建立和操作

1.将查询超过18岁的学生的结果建立视图view1,所有男同学的结果建立view2

create view view1 as select * from student where sage>18create view view2 as select * from student where ssex='';

A.在student中,将CS 改为CC,  view1,view2 有没有同步更改?

update student set sdept='cc' where sdept='cs';

同步更改了。

B.在view1中将女同学改为男同学,student 及view2有没有同步修改?

update view1 set ssex='' where ssex='';

同步更改了。

2. 将查询成绩及格(>=60)的姓名、系名、课程名和成绩的结果建立视图V1
然后对视图V1进行update, delete和insert操作,观察student,course和 sc三张基表的变化.

create view v1 as
select student.sname,student.sdept,course.cname,sc.grade from student,sc,course
where student.sno=sc.sno and course.cno=sc.cno
and grade>=60;

A.在student,course和 sc三表中进行update, delete和insert操作(自己设计测试用例),观察V1视图的变化.    同步变化
B.在V1视图中进行update, delete和insert操作(自己设计测试用例),观察student,course和 sc三张基表的变化.    同步变化

3.将查询超过平均成绩的学号、课程号及成绩的结果建立一个视图V2

create view v2 as select sno, cno,grade from sc where grade >(select avg(grade) from sc) 

A.在sc表中进行update, delete和insert操作(自己设计测试用例),观察V2视图的变化.     同步变化
B.在V2视图中进行update, delete和insert操作(自己设计测试用例),观察sc基表的变化,并且分析原因.     同步变化

 

**结论:view视图是基于表的,当表中的内容更改时,视图中的内容也会更改,当更改视图时,同样表中的内容也会更改,二者互相关联。

 

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
6天前
|
存储 人工智能 Cloud Native
云栖重磅|从数据到智能:Data+AI驱动的云原生数据库
在9月20日2024云栖大会上,阿里云智能集团副总裁,数据库产品事业部负责人,ACM、CCF、IEEE会士(Fellow)李飞飞发表《从数据到智能:Data+AI驱动的云原生数据库》主题演讲。他表示,数据是生成式AI的核心资产,大模型时代的数据管理系统需具备多模处理和实时分析能力。阿里云瑶池将数据+AI全面融合,构建一站式多模数据管理平台,以数据驱动决策与创新,为用户提供像“搭积木”一样易用、好用、高可用的使用体验。
云栖重磅|从数据到智能:Data+AI驱动的云原生数据库
|
8天前
|
SQL 关系型数据库 数据库
国产数据实战之docker部署MyWebSQL数据库管理工具
【10月更文挑战第23天】国产数据实战之docker部署MyWebSQL数据库管理工具
43 4
国产数据实战之docker部署MyWebSQL数据库管理工具
|
1天前
|
SQL 前端开发 关系型数据库
SpringBoot使用mysql查询昨天、今天、过去一周、过去半年、过去一年数据
SpringBoot使用mysql查询昨天、今天、过去一周、过去半年、过去一年数据
25 9
|
6天前
|
关系型数据库 分布式数据库 数据库
云栖大会|从数据到决策:AI时代数据库如何实现高效数据管理?
在2024云栖大会「海量数据的高效存储与管理」专场,阿里云瑶池讲师团携手AMD、FunPlus、太美医疗科技、中石化、平安科技以及小赢科技、迅雷集团的资深技术专家深入分享了阿里云在OLTP方向的最新技术进展和行业最佳实践。
|
9天前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。同时,文章还对比了编译源码安装与使用 RPM 包安装的优缺点,帮助读者根据需求选择最合适的方法。通过具体案例,展示了编译源码安装的灵活性和定制性。
45 2
|
9天前
|
SQL 关系型数据库 MySQL
定时任务频繁插入数据导致锁表问题 -> 查询mysql进程
定时任务频繁插入数据导致锁表问题 -> 查询mysql进程
23 1
|
7天前
|
监控 关系型数据库 MySQL
数据库优化:MySQL索引策略与查询性能调优实战
【10月更文挑战第27天】本文深入探讨了MySQL的索引策略和查询性能调优技巧。通过介绍B-Tree索引、哈希索引和全文索引等不同类型,以及如何创建和维护索引,结合实战案例分析查询执行计划,帮助读者掌握提升查询性能的方法。定期优化索引和调整查询语句是提高数据库性能的关键。
38 0
|
7天前
|
监控 关系型数据库 MySQL
数据库优化:MySQL索引策略与查询性能调优实战
【10月更文挑战第26天】数据库作为现代应用系统的核心组件,其性能优化至关重要。本文主要探讨MySQL的索引策略与查询性能调优。通过合理创建索引(如B-Tree、复合索引)和优化查询语句(如使用EXPLAIN、优化分页查询),可以显著提升数据库的响应速度和稳定性。实践中还需定期审查慢查询日志,持续优化性能。
34 0
|
23天前
|
存储 关系型数据库 MySQL
Mysql(4)—数据库索引
数据库索引是用于提高数据检索效率的数据结构,类似于书籍中的索引。它允许用户快速找到数据,而无需扫描整个表。MySQL中的索引可以显著提升查询速度,使数据库操作更加高效。索引的发展经历了从无索引、简单索引到B-树、哈希索引、位图索引、全文索引等多个阶段。
56 3
Mysql(4)—数据库索引
|
12天前
|
存储 关系型数据库 MySQL
MySQL vs. PostgreSQL:选择适合你的开源数据库
在众多开源数据库中,MySQL和PostgreSQL无疑是最受欢迎的两个。它们都有着强大的功能、广泛的社区支持和丰富的生态系统。然而,它们在设计理念、性能特点、功能特性等方面存在着显著的差异。本文将从这三个方面对MySQL和PostgreSQL进行比较,以帮助您选择更适合您需求的开源数据库。
53 4