MySQL索引&视图&存储过程

来自拉钩教育-JAVA就业集训营

1. MySQL索引
2. MySQL 视图
3. MySQL 存储过程(了解)
4. MySQL触发器(了解)

----------------------------------------------------------

1. MySQL 索引

1.1 什么是索引

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

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

1.2索引的分类

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

1.2.1主键索引

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

1.语法格式

  • 创建表时 添加主键索引
 create table 表名(
  -- 添加主键 (主键是唯一性索引,不能为null,不能重复,)
  字段名 字段类型 primary key,
);
  • 修改表结构 添加主键索引
 alter table 表名 add primary key( 列名 );

1.2.2 唯一索引(UNIQUE)

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

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

  1. 语法格式
  • 创建表的时候直接添加主键索引
 create table 表名(
  列名 类型(长度),
  unique  [索引名称]  (列名)
);
  • 使用create语句创建: 在已有的表上创建索引
  create unique index 索引名 on 表名(列名(长度));
  • 修改表结构添加索引
alter table 表名 add unique (列名)

1.2.3 普通索引 (INDEX)

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

  • 使用create index 语法创建:在已有的表上创建索引
 create index 索引名 on 表名(列名(长度));
  • 修改表结构添加索引
 alter table 表名 add index 索引名 (列名)

1.2.4 删除索引

  • 由于索引会占用一定的磁盘空间,因此,为了避免影响数据库的性能,应该及时删除不再使用的索引
    1.语法格式
 alter table 表名 drop index 索引名;

1.4 索引的优缺点总结

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

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

索引的缺点

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

2. MySQL 视图

2.1 什么是视图

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

2.2 视图的作用

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

2.3 视图的使用

2.3.1创建视图

1.语法格式

  create view 视图名 [column_list] as select 语句;
  view : 代表视图
  column_list : 可选参数,表示属性清单,指定视图中各个属性的名称,默认情况下,与SELECT语句中查询的属性相同
  as : 表示视图要执行的操作
  select语句: 向视图提供数据内容
  1. 需求: 查询鞋服分类下最贵的商品的全部信息
 #通过连表查询
 #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.存储过程一旦调试完成后,就可以稳定运行,(前提是,业务需求要相对稳定,没有变化)
    2.存储过程减少业务系统与数据库的交互,降低耦合,数据库交互更加快捷(应用服务器,与数据库服务器不在同一个地区)
  • 缺点:
    1.在互联网行业中,大量使用MySQL,MySQL的存储过程与Oracle的相比较弱,所以较少使用,并且互联网行业需求变化较快也是原因之一
    2.尽量在简单的逻辑中使用,存储过程移植十分困难,数据库集群环境,保证各个库之间存储过程变更一致也十分困难。
    3.阿里的代码规范里也提出了禁止使用存储过程,存储过程维护起来的确麻烦;


    image.png

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);
  1. 创建简单的存储过程
    语法格式
 delimiter $$  -- 自定义语句结束标识符 一般使用$$
 create procedure 存储过程名()  
    begin    -- 开始编写存储过程
            -- 要执行的操作
    end $$    --存储过程结束
  1. 创建简单的存储过程
 delimiter $$
 create procedure good_proc()
    begin
      select * from goods;
    end  $$
  1. 调用存储过程
    语法格式
 call 存储过程名
 # 调用存储过程 查询goods表所有数据
 call goods_proc;

3.3.2 方式2

  1. IN 输入参数:表示调用者向存储过程传入值
create procedure 存储过程名称(IN 参数名 参数类型);
  1. 创建接收参数的存储过程
    需求: 接收一个商品id, 根据id删除数据
 delimiter $$;
  create procedure good_proc02(in goods_id int)
    begin
        delete from goods where gid = goods_id;
    end $$

3.调用存储过程,传递参数

  #删除 id为2的商品
  call  goods_proc02(2);

3.3.3 方式3

  1. 变量赋值
  set @变量名=值
  1. OUT 输出参数:表示存储过程向调用者传出值
  out  变量名 数据类型
  1. 创建存储过程
    需求: 向订单表 插入一条数据, 返回1,表示插入成功
 # 创建存储过程 接收参数插入数据, 并返回受影响的行数
 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 $$
  1. 调用存储过程
  # 调用存储过程插入数据,获取返回值
  CALL orders_proc(1,2,30,@out_num);
image.png

4. MySQL触发器(了解)

4.1 什么是触发器

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

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

4.2 触发器创建的四个要素

  1. 监视地点(table)
  2. 监视事件(insert/update/delete)
  3. 触发时间(before/after)
  4. 触发事件(insert/update/delete)

4.3 创建触发器

  1. 语法格式
 delimiter $ # 将Mysql的结束符号从 ; 改为 $,避免执行出现错误
 CREATE TRIGGER Trigger_Name # 触发器名,在一个数据库中触发器名是唯一的
 before/after(insert/update/delete) # 触发的时机 和 监视的事件
 on table_Name # 触发器所在的表
 for each row # 固定写法 叫做行触发器, 每一行受影响,触发事件都执行
 begin
 # begin和end之间写触发事件
 end
 $ # 结束标记
  1. 向商品中添加一条数据
  # 向商品中添加一条数据
  insert into goods values(1,'book',40);
  1. 需求: 在下订单的时候,对应的商品的库存量要相应的减少,卖出商品之后减少库存量。
# 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$
  1. 查询 goods表中的数据


    image.png
  2. 向订单表中添加一条数据
  insert into orders values(1,1,25);
  1. goods表中的数据随之 -1
image.png

5. DCL(数据控制语言)

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

5.1 创建用户

语法格式

 create user '用户名'@'主机名' identified BY '密码';
参数 说明
用户名 创建的新用户,登录名称
主机名 指定该用户在哪个主机上可以登陆,本地用户可用 localhost 如果想让该用户可以 从任意远程主机登陆,可以使用通配符 %
密码 登录密码
  1. 创建 admin1 用户,只能在 localhost 这个服务器登录 mysql 服务器,密码为 123456
  • 创建的用户在名字为 mysql的 数据库中的 user表中


    image.png
  CREATE USER 'admin1'@'localhost' IDENTIFIED BY '123456';
  1. 创建 admin2 用户可以在任何电脑上登录 mysql 服务器,密码为 123456


    image.png
  • % 表示 用户可以在任意电脑登录 mysql服务器.

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';
  1. 给 admin2 用户分配所有权限,对所有数据库的所有表
  GRANT ALL ON *.* TO 'admin2'@'%';
  1. 使用admin1用户登录数据库 测试权限

  2. 发现数据库列表中 只有db4, 表只有 products


    image.png
  3. 执行查询操作

  # 查询account表
 SELECT * FROM products;
  1. 执行插入操作,发现不允许执行,没有权限
# 向 products 表中插入数据
# 不允许执行
insert into products values('p010','小鸟伏特加',1000,1,NULL);

5.3 查看权限
语法格式

  show grants for '用户名'@'主机名';
  1. 查看root用户权限
    -- 查看root用户的权限
show grants for 'root'@'localhost';
  • GRANT ALL PRIVILEGES 是表示所有权限


    image.png

5.4 删除用户

语法格式

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

5.5 查询用户

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

# 查询用户
SELECT * FROM USER

你可能感兴趣的:(MySQL索引&视图&存储过程)