文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

mysql基础(九) 索引和视图

2024-04-02 19:55

关注
索引:是一种按照特定存储格式存储的特殊数据,用于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

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


阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯