任务四_MySQL索引&视图&存储过程

    笔记内容输出来源:拉勾教育Java大数据学科 训练营;

目录

 

1. MySQL 索引

1.1 什么是索引

1.2 常见索引分类

1.2.1 主键索引 (PRIMARY KEY)

1.2.2 唯一索引(UNIQUE)

1.2.3 普通索引 (INDEX)

1.2.4 删除索引

1.4 索引的优缺点总结

2. MySQL 视图

2.1 什么是视图

2.2 视图的作用

2.3 视图的使用

2.3.1 创建视图

2.3.2 通过视图进行查询

2.4 视图与表的区别

3. MySQL 存储过程(了解)

3.1 什么是存储过程

3.2 存储过程的优缺点

 3.3 存储过程的创建方式

3.3.1 方式1

3.3.2 方式2

3.3.3 方式3

4. MySQL触发器(了解)

4.2 触发器创建的四个要素

5. DCL(数据控制语言)

5.1 创建用户

5.2 用户授权

5.3 查看权限

5.5 查询用户

6. 数据库备份&还原

6.1 SQLYog 数据备份

6.2 SQLYog 数据恢复

6.3 命令行备份


1. MySQL 索引

1.1 什么是索引

在数据库表中,对字段建立索引可以大大提高查询速度。通过善用这些索引,可以令MySQL的查询和 运行更加高效。

如果合理的设计且使用索引的MySQL是一辆兰博基尼的话,那么没有设计和使用索引的MySQL就是 一个人力三轮车。拿汉语字典的目录页(索引)打比方,我们可以按拼音、笔画、偏旁部首等排序的目 录(索引)快速查找到需要的字

1.2 常见索引分类

索引名称说明
主键索引 (primary key)主键是一种唯一性索引,每个表只能有一个主键, 用于标识数据表中的每一 条记录
唯一索引 (unique)唯一索引指的是 索引列的所有值都只能出现一次, 必须唯一
普通索引 (index)最常见的索引,作用就是 加快对数据的访问速度

 

 

 

 

 

 MySql将一个表的索引都保存在同一个索引文件中, 如果对中数据进行增删改操作,MySql都会自动的更 新索引.

1.2.1 主键索引 (PRIMARY KEY)

  • 特点: 主键是一种唯一性索引,每个表只能有一个主键,用于标识数据表中的某一条记录。
  • 一个表可以没有主键,但最多只能有一个主键,并且主键值不能包含NULL。
  •  

 3) 语法格式

创建表的时候直接添加主键索引 (最常用)

CREATE TABLE 表名(
-- 添加主键 (主键是唯一性索引,不能为null,不能重复,)
字段名 类型 PRIMARY KEY,
);

修改表结构 添加主键索引

ALTER TABLE 表名 ADD PRIMARY KEY ( 列名 )

4) 为demo1 表添加主键索引

ALTER TABLE demo01 ADD PRIMARY KEY (did);

1.2.2 唯一索引(UNIQUE)

特点: 索引列的所有值都只能出现一次, 必须唯一

唯一索引可以保证数据记录的唯一性。事实上,在许多场合,人们创建唯一索引的目的往往不是为了 提高访问速度,而只是为了避免数据出现重复。

) 语法格式

创建表的时候直接添加主键索引

CREATE TABLE 表名(
列名 类型(长度),
-- 添加唯一索引
UNIQUE [索引名称] (列名)
);
 CREATE TABLE `wb_blog` (  

    ->   `id` smallint(8) unsigned NOT NULL,  
    ->   `catid` smallint(5) unsigned NOT NULL DEFAULT '0',  

    ->   `title` varchar(80) NOT NULL DEFAULT '',  
     ->   `content` text NOT NULL,  

   ->   PRIMARY KEY (`id`),  

    ->   UNIQUE KEY `catename` (`catid`)  

    -> ) ;

使用create语句创建: 在已有的表上创建索引

create unique index 索引名 on 表名(列名(长度))
create unique index ind_hobby on demo01(hobby

修改表结构添加索引

ALTER TABLE 表名 ADD UNIQUE ( 列名 )

1.2.3 普通索引 (INDEX)

普通索引(由关键字KEY或INDEX定义的索引)的唯一任务是加快对数据的访问速度。因此,应该只 为那些最经常出现在查询条件(WHERE column=)或排序条件(ORDERBY column)中的数据列创建 索引。

1) 语法格式

-- 使用create index 语句创建: 在已有的表上创建索引
create index 索引名 on 表名(列名[长度])
-- 修改表结构添加索引
ALTER TABLE 表名 ADD INDEX 索引名 (列名)
alter table demo01 add index dname_indx(dname);

1.2.4 删除索引

由于索引会占用一定的磁盘空间,因此,为了避免影响数据库的性能,应该及时删除不再使用的索 引

1) 语法格式

ALTER TABLE table_name DROP INDEX index_name;
ALTER TABLE demo01 DROP INDEX dname_indx;

1.4 索引的优缺点总结

添加索引首先应考虑在 where 及 order by 涉及的列上建立索引。

索引的优点

  • 1. 大大的提高查询速度
  • 2. 可以显著的减少查询中分组和排序的时间。

 索引的缺点

  • 1. 创建索引和维护索引需要时间,而且数据量越大时间越长
  • 2. 当对表中的数据进行增加,修改,删除的时候,索引也要同时进行维护,降低了数据的维护 速度

2. MySQL 视图

2.1 什么是视图

  • 1. 视图是一种虚拟表。
  • 2. 视图建立在已有表的基础上, 视图赖以建立的这些表称为基表。
  • 3. 向视图提供数据内容的语句为 SELECT 语句, 可以将视图理解为存储起来的 SELECT 语句.
  • 4. 视图向用户提供基表数据的另一种表现形式

2.2 视图的作用

  1. 权限控制时可以使用
  • 比如,某几个列可以运行用户查询,其他列不允许,可以开通视图 查询特定的列, 起到权限控制的 作用
  1. 简化复杂的多表查询
  • 视图 本身就是一条查询SQL,我们可以将一次复杂的查询 构建成一张视图, 用户只要查询视图 就可以获取想要得到的信息(不需要再编写复杂的SQL)
  • 视图主要就是为了简化多表的查询

2.3 视图的使用

2.3.1 创建视图

1) 语法格式

create view 视图名 [column_list] as select语句;
view: 表示视图
column_list: 可选参数,表示属性清单,指定视图中各个属性的名称,默认情况下,与SELECT语句中查询
的属性相同
as : 表示视图要执行的操作
select语句: 向视图提供数据内容

 

2) 创建一张视图

#1. 先编写查询语句
#查询所有商品 和 商品的对应分类信息
SELECT * FROM products p LEFT JOIN category c ON p.`category_id` = c.`cid`;
#2.基于上面的查询语句,创建一张视图
CREATE VIEW products_category_view
AS SELECT * FROM products p LEFT JOIN category c ON p.`category_id` = c.`cid`;

3) 查询视图 ,当做一张只读的表操作就可以

SELECT * FROM products_category_view;

2.3.2 通过视图进行查询

1) 需求: 查询各个分类下的商品平均价格

#通过 多表查询
SELECT
cname AS '分类名称',
AVG(p.`price`) AS '平均价格'
FROM products p LEFT JOIN category c ON p.`category_id` = c.`cid`
GROUP BY c.`cname`;
# 通过视图查询 可以省略连表的操作
SELECT
cname AS '分类名称',
AVG(price) AS '平均价格'
FROM products_category_view GROUP BY cname;

2) 需求: 查询鞋服分类下最贵的商品的全部信息

#通过连表查询
#1.先求出鞋服分类下的最高商品价格
SELECT
MAX(price) AS maxPrice
FROM
products p LEFT JOIN category c ON p.`category_id` = c.`cid`
WHERE c.`cname` = '鞋服'
#2.将上面的查询 作为条件使用
SELECT * FROM products p LEFT JOIN category c ON p.`category_id` = c.`cid`
WHERE c.`cname` = '鞋服' AND p.`price` =
(SELECT
MAX(price) AS maxPrice
FROM
products p LEFT JOIN category c ON p.`category_id` = c.`cid`
WHERE c.`cname` = '鞋服');
#通过视图查询
SELECT * FROM products_category_view pcv
WHERE pcv.`cname` = '鞋服'
AND pcv.`price` = (SELECT MAX(price) FROM products_category_view WHERE cname =
'鞋服')

2.4 视图与表的区别

  • 视图是建立在表的基础上,表存储数据库中的数据,而视图只是做一个数据的展示
  • 通过视图不能改变表中数据(一般情况下视图中的数据都是表中的列 经过计算得到的结果,不允许 更新)
  • 删除视图,表不受影响,而删除表,视图不再起作用

3. MySQL 存储过程(了解)

3.1 什么是存储过程

MySQL 5.0 版本开始支持存储过程

存储过程(Stored Procedure)是一种在数据库中存储复杂程序,以便外部程序调用的一种数据 库对象。存储过程是为了完成特定功能的SQL语句集,经编译创建并保存在数据库中,用户可通过 指定存储过程的名字并给定参数(需要时)来调用执行。

简单理解: 存储过程其实就是一堆 SQL 语句的合并。中间加入了一些逻辑控制。

3.2 存储过程的优缺点

  • 优点:
  1. 存储过程一旦调试完成后,就可以稳定运行,(前提是,业务需求要相对稳定,没有变化) 存储过程减少业务系统与数据库的交互,降低耦合,数据库交互更加快捷(应用服务器,与 数据库服务器不在同一个地区)
  • 缺点
  1. 在互联网行业中,大量使用MySQL,MySQL的存储过程与Oracle的相比较弱,所以较少使 用,并且互联网行业需求变化较快也是原因之一
  2. 尽量在简单的逻辑中使用,存储过程移植十分困难,数据库集群环境,保证各个库之间存储 过程变更一致也十分困难。
  3. 阿里的代码规范里也提出了禁止使用存储过程,存储过程维护起来的确麻烦;

 3.3 存储过程的创建方式

3.3.1 方式1

1) 数据准备

创建商品表 与 订单表

# 商品表
CREATE TABLE goods(
gid INT,
NAME VARCHAR(20),
num INT -- 库存
);
#订单表
CREATE TABLE orders(
oid INT,
gid INT,
price INT -- 订单价格
);
# 向商品表中添加3条数据
INSERT INTO goods VALUES(1,'奶茶',20);
INSERT INTO goods VALUES(2,'绿茶',100);
INSERT INTO goods VALUES(3,'花茶',25);

2) 创建简单的存储过程

语法格式

DELIMITER $$ -- 声明语句结束符,可以自定义 一般使用$$
CREATE PROCEDURE 过程名称() -- 声明存储过程
BEGIN -- 开始编写存储过程
-- 要执行的操作
END $$ -- 存储过程结束

需求: 编写存储过程, 查询所有商品数据

DELIMITER $$
CREATE PROCEDURE goods_proc()
BEGIN
select * from goods;
END $$

3) 调用存储过程

语法格式

-- 调用存储过程 查询goods表所有数据
call goods_proc;

3.3.2 方式2

CREATE PROCEDURE 存储过程名称(IN 参数名 参数类型)
DELIMITER $$
CREATE PROCEDURE goods_proc02(IN goods_id INT)
BEGIN
DELETE FROM goods WHERE gid = goods_id ;
END $$
# 删除 id为2的商品
CALL goods_proc02(2);

3.3.3 方式3

1) 变量赋值

SET @变量名=值

2) OUT 输出参数:表示存储过程向调用者传出值

OUT 变量名 数据类型

3) 创建存储过程

# 创建存储过程 接收参数插入数据, 并返回受影响的行数
DELIMITER $$
CREATE PROCEDURE orders_proc(IN o_oid INT , IN o_gid INT ,IN o_price INT, OUT
out_num INT)
BEGIN
-- 执行插入操作
INSERT INTO orders VALUES(o_oid,o_gid,o_price);
-- 设置 num的值为 1
SET @out_num = 1;
-- 返回 out_num的值
SELECT @out_num;
END $$
# 调用存储过程插入数据,获取返回值
CALL orders_proc(1,2,30,@out_num);

4. MySQL触发器(了解)

触发器(trigger)是MySQL提供给程序员和数据分析员来保证数据完整性的一种方法,它是与表事 件相关的特殊的存储过程,它的执行不是由程序调用,也不是手工启动,而是由事件来触发,比如当对 一个表进行操作(insert,delete, update)时就会激活它执行。——百度百科

简单理解: 当我们执行一条sql语句的时候,这条sql语句的执行会自动去触发执行其他的sql语句。

4.2 触发器创建的四个要素

  • 1. 监视地点(table)
  • 2. 监视事件(insert/update/delete)
  • 3. 触发时间(before/after)
  • 4. 触发事件(insert/update/delete)
delimiter $ -- 将Mysql的结束符号从 ; 改为 $,避免执行出现错误
CREATE TRIGGER Trigger_Name -- 触发器名,在一个数据库中触发器名是唯一的
before/after(insert/update/delete) -- 触发的时机 和 监视的事件
on table_Name -- 触发器所在的表
for each row -- 固定写法 叫做行触发器, 每一行受影响,触发事件都执行
begin
-- begin和end之间写触发事件
end
$ -- 结束标记

# 向商品中添加一条数据 INSERT INTO goods VALUES(1,'book',40);

-- 1.修改结束标识
DELIMITER $
-- 2.创建触发器
CREATE TRIGGER t1
-- 3.指定触发的时机,和要监听的表
AFTER INSERT ON orders
-- 4.行触发器 固定写法
FOR EACH ROW
-- 4.触发后具体要执行的事件
BEGIN
-- 订单+1 库存-1
UPDATE goods SET num = num -1 WHERE gid = 1;
END$
INSERT INTO orders VALUES(1,1,25);

5. DCL(数据控制语言)

MySql默认使用的都是 root 用户,超级管理员,拥有全部的权限。除了root用户以外,我们还可以通 过DCL语言来定义一些权限较小的用户, 分配不同的权限来管理和维护数据库。

5.1 创建用户

CREATE USER '用户名'@'主机名' IDENTIFIED BY '密码';

1) 创建 admin1 用户,只能在 localhost 这个服务器登录 mysql 服务器,密码为 123456

CREATE USER 'admin1'@'localhost' IDENTIFIED BY '123456';

2) 创建 admin2 用户可以在任何电脑上登录 mysql 服务器,密码为 123456

CREATE USER 'admin2'@'%' IDENTIFIED BY '123456';

5.2 用户授权

GRANT 权限 1, 权限 2... ON 数据库名.表名 TO '用户名'@'主机名';

`

参数说明
权限授予用户的权限,如 CREATE、ALTER、SELECT、INSERT、UPDATE 等。 如果要授 予所有的权限则使用 ALL
ON用来指定权限针对哪些库和表。
TO表示将权限赋予某个用户。

 

 

 

 

 

1) 给 admin1 用户分配对 db4 数据库中 products 表的 操作权限:查询 

 

GRANT SELECT ON db4.products TO 'admin1'@'localhost';

2) 给 admin2 用户分配所有权限,对所有数据库的所有表

GRANT ALL ON *.* TO 'admin2'@'%';

5.3 查看权限

语法格式

SHOW GRANTS FOR '用户名'@'主机名';

1) 查看root用户权限

-- 查看root用户的权限
SHOW GRANTS FOR 'root'@'localhost';

5.4 删除用户

DROP USER '用户名'@'主机名';
-- 删除 admin1 用户
DROP USER 'admin1'@'localhost';

5.5 查询用户

选择名为 mysql的数据库, 直接查询 user表即可

-- 查询用户
SELECT * FROM USER;

6. 数据库备份&还原

6.1 SQLYog 数据备份

1) 选中要备份的数据库,右键 备份导出 ---->选择 备份数据库

6.2 SQLYog 数据恢复

1) 先删除 db2 数据库

DROP DATABASE db2

2) 导入 之前备份的 SQL 文件

6.3 命令行备份

mysqldump -u 用户名 -p 密码 数据库 > 文件路径
mysqldump -uroot -p123456 db2 > H:/db2.sql
-- 恢复数据 还原 db2 数据库中的数据
-- 注意:还原的时候需要先创建一个 db2数据库
source sql文件地址

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

大数据专家大神

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值