设为首页 收藏本站
查看: 911|回复: 0

[经验分享] mysql基础(九) 索引和视图

[复制链接]

尚未签到

发表于 2018-10-9 06:31:34 | 显示全部楼层 |阅读模式
索引:是一种按照特定存储格式存储的特殊数据,用于SQL查询  
索引的类型:
  
    聚集索引和非聚集索引:数据是否和索引存储在一起
  
  主键索引和辅助索引:索引是否在主键之上
  
  左前缀索引和覆盖索引:是否只截取左边的前几个字节最为索引,mysql默认使用左前缀索引
  
左前缀索引的存储:
  
  在指定索引的字段中截取左边的前几个字节生成索引,并对索引进行排序处理,将排完序的索引进行分组管理
  
  并生成源数据,当用户以索引字段作为查询条件时,mysql去扫描元数据,并定位到元数据对应数据的上
  

  
索引管理:
  
  CREATE INDEX 索引名 ON 表名 (字段名);#创建索引
  
  SHOW INDEX FROM 表名;#查看指定表的索引
  
    DROP INDEX 索引名 ON 表名;#删除索引
  
    注意:索引没必要修改,因为没有意义
  

  
示例:
  
    USE mysql;#使用mysql库
  
    CREATE INDEX test_index ON user (User);#在user表的User字段索引
  
    SHOW INDEX FROM user;#查看索引是否创建成功
  
    EXPLAIN SELECT * FROM user WHERE User='root'\G;
  
        #使用EXPLAIN查看命令的执行过程(不会真正的去执行)
  

  #使用索引的查询过程
  id: 1#编号
  select_type: SIMPLE#查询类型   SIMPLE:表示简单查询
  table: user#查询关联到的表
  type: ref    #访问类型
  possible_keys: test_index#可能会用到的索引
  key: test_index#最终用到的索引
  key_len: 48#在索引中使用的字节数
  
          ref: const#一对一查询
  
              rows: 3#为找到目标行而读取的行
  Extra: Using where#额外信息
  
    常见访问类型:ALL:全表扫描  index:根据索引进行全表扫描  range:范围扫描
  
    ref:更具索引返回表中匹配的值所在的行 const/system:直接返回单行(一般基于主键查询)
  

  

  #没有使用索引的查询过程
  id: 1
  select_type: SIMPLE
  table: user
  type: ALL#全表扫描查询
  possible_keys: NULL
  key: NULL
  key_len: NULL
  ref: NULL
  rows: 6
  Extra: Using where
  

  

  

  
视图管理:
  
    视图也叫虚表,是由select语句生成,mysql的视图较为不稳定,不建议使用
  
  CREATE VIEW 视图名 AS select语句#创建视图
  
  DROP VIEW 视图名 #删除视图
  

  
示例:
  
  CREATE DATABASE mydb;    #创建测试数据库
  
  USE mydb;    #使用测试数据库
  
  CREATE VIEW test_view AS SELECT User,Host,Password FROM mysql.user;#创建视图
  
  SELECT * FROM test_view;            #查看视图内容
  
  SHOW TABLE STATUS LIKE 'test_view'\G;    #查看视图状态
  Name: test_view
  Engine: NULL
  Version: NULL
  
    Row_format: NULL
  Rows: NULL
  
  Avg_row_length: NULL
  
    Data_length: NULL
  
  Max_data_length: NULL
  
   Index_length: NULL
  
     Data_free: NULL
  
  Auto_increment: NULL
  
    Create_time: NULL
  
    Update_time: NULL
  
    Check_time: NULL
  
        Collation: NULL
  Checksum: NULL
  
    Create_options: NULL
  
       Comment: VIEW
  

  注意:视图的修改其实是修改基表的数据(慎用)



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-617887-1-1.html 上篇帖子: centos7 如何安装MySQL --详细安装 下篇帖子: mysql5.6.20二进制安装
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表