MySQL数据库视图和索引

一、视图

1.什么是视图?

视图是一张虚拟表,并不在数据库中以存储数据值集的形式存在。在引用过程中依据基表动态生成。

2.为什么使用视图?

安全:有的数据是需要保密的,如果直接把表给出来进行操作会造成泄密,那么可以通过创建视图把相应视图的权限给出来即可保证数据的安全。

高效:复杂的连接查询,每次执行时效率比较低,可以考虑新建视图,每次从视图中获取,将会提高效率。

定制数据:将常用的字段放置在视图中。

3.如何使用视图?

3.1 创建视图

#查看10号部门所有的员工信息,新建视图

create view shitu as select * from table;

3.2 查询视图

select * from shitu;

3.3 修改视图

#将基表的name字段修改了

update shitu set name='kitty' where id=7839;

#将视图包含的deptno均修改为20,在基表中修改

update shitu set deptno=20;

#结果集为空,基表中不存在10号部门了

select * from shitu;

with check option保证视图查询条件不被修改,但其他字段可以修改

create view v_emp as select * from emp where deptno=10 with check option;

3.4 删除视图

#删除视图(DDL操作)

drop view v_emp;

3.5 注意事项

通过视图可以修改基表数据,但视图一般只做查询。

with check option关键词词用于保证视图的查询条件不被修改,但其他字段可以修改。

二、索引

1.什么是索引?

索引是供服务器快速在表中查询一行数据的数据结构,可以比作书籍的目录。mysql中的索引的默认数据结构是B-Tree。

2.为什么使用索引?

2.1 性能指标

性能从高到低依次是:

system>const>eq_ref>ref>fulltext>ref_or_null>index_merge>unique_subquery>index_subquery>range>index>ALL,其中all表示全表扫描。一般来说,查询至少达到range级别,最好能达到ref级别。否则,sql的查询性能会很慢。

2.2 查询语句性能比较

关键词explain:查看sql执行性能

#解释计划任务

#explain:查看sql执行性能

#性能级别:const,查询1row

explain select * from emp where empno=7788;

#性能级别:all(全表扫描),查询14row

explain select * from emp where ename='scott';

代码说明:为什么第1条查询比第2条查询快这么多?第1条语句的条件字段是主键,主键自动创建索引,根据记录地址查找;而第2条语句的条件是普通字段,做的是全表扫描。

2.如何使用索引?(创建、删除)

2.1 普通索引

create index index_name on tname(fie1...);

#创建普通单列索引,多个列用逗号隔开

create index index_name on emp(ename);

#性能级别:ref,查询1row

explain select * from emp where ename='scott';

#删除索引

drop index index_name on emp;

2.2 唯一索引

与普通索引区别是指定列的数据必须是唯一的,主键、唯一约束、外键等都会自动添加索引。

#创建唯一索引,唯一约束也会添加唯一索引

···

create unique index index_name on tname(fie);

3.适用场景有哪些?

表数据量足够大;

增删改较少的表;

高基数列。什么意思?该列的数据大多数都不一样。

4.注意事项有哪些?

索引需要单独开辟空间进行维护,对数据进行增删改,都需要维护索引。所以索引不易添加过多;

将条件列设置索引(经常作为条件的列);

索引失效的状况:比如or关键字会导致索引失效

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值