MySQL之视图索引执行计划

目录

一.视图

二.执行计划

2.1.什么是执行计划

2.2.执行计划的作用

三.使用外连接、内连接和子查询进行举例

四.思维导图

             好啦今天就到这里了哦!!!希望能帮到你哦!!! 


一.视图

含义 :在数据库中,视图是一种虚拟表,它是基于一个或多个实际表的查询结果。视图提供了一种抽象层,允许用户以一种更简单或更特定的方式查看数据。视图并不存储实际数据,而是根据定义在其上的查询实时生成数据。虚拟表,和普通表一样使用。

操作:

创建视图:create view 视图名 as  查询语句;

视图的修改:方式一:create or replace view 视图名 as 查询语句;

方式二:alter view 视图名 as 查询语句;

删除视图:drop view 视图名,视图名,…….;

查看视图:DESC  视图名 (查看视图相关字段)

SHOW CREATE VIEW 视图名; (查看视图相关语句)

 例子:

CREATE VIEW v_student_score
as
SELECT s.*,sc.cid,sc.score from  t_mysql_student s,t_mysql_score
sc where s.sid = sc.sid;


SELECT * from v_student_score;

desc v_student_score;

SHOW CREATE VIEW v_student_score;

CREATE VIEW v_student_score
as
SELECT s.*,sc.cid,sc.score from  t_mysql_student s,t_mysql_score
sc where s.sid = sc.sid;

drop view v_student_score;

建好之后直接查询一手

 只能查看字段

 查看视图相关语句

 

 删除视图

 

二.执行计划

2.1.什么是执行计划

使用EXPLAIN 关键字可以模拟优化器执行SQL查询语句,从而知道MYSQL是如何处理你的sql语句的。分析你的查询语句或是表结构的性能瓶颈

2.2.执行计划的作用

  • 表的读取顺序
  • 数据的读取操作类型
  • 那些索引可以使用
  • 那些索引被实际使用
  • 表之间的引用
  • 每张表有多少行被优化器查

三.使用外连接、内连接和子查询进行举例

  • 01)查询" 01 "课程比" 02 "课程成绩高的学生的信息及课程分数
  1. 涉及表:t_mysql_student , t_mysql_score
  2. 连接方式:内连接 
  3. 行转列:流程控制函数    

  • 02)查询同时存在" 01 "课程和" 02 "课程的情况
  1. 涉及表:t_mysql_student , t_mysql_score
  2. 连接方式:内连接 
  3. 行转列:流程控制函数    

 

  • 03)查询存在" 01 "课程但可能不存在" 02 "课程的情况(不存在时显示为 null )
  1. 涉及表:t_mysql_score
  2. 连接方式:外连接 
  3. 以01课表为主

推荐:上面的这种查询方式看着不太友好,所以还有另外的一种,加上学生的信息: 

  1. 涉及表:t_mysql_student , t_mysql_score
  2. 连接方式:内连接,外连接
  3. 行转列:流程控制函数    
  4. 可以更加直接的看到那个学生哪门课程没有学习,一目了然,是看的舒服多了

 

  • 04)查询不存在" 01 "课程但存在" 02 "课程的情况
  1. 涉及表:t_mysql_student , t_mysql_score
  2. 查询方式:子查询
  3. 行转列:流程控制函数    

 

  • 05)查询平均成绩大于等于 60 分的同学的学生编号和学生姓名和平均成绩
  1. 涉及表:t_mysql_student , t_mysql_score
  2. 查询方式:外连接
  3. 聚合函数:四舍五入( round() ),平均值( avg() 
  4. 有聚合函数意味着分组( GROUP BY )

 

  • 06)查询在t_mysql_score表存在成绩的学生信息
  1. 涉及表:t_mysql_student , t_mysql_score
  2. 查询方式:内连接
  3. 最后建议进行一次分组,不然数据过多

 

 07)查询所有同学的学生编号、学生姓名、选课总数、所有课程的总成绩(没成绩的显示为 null )
涉及表:t_mysql_student , t_mysql_score
查询方式:外连接
聚合函数:计数( count() ),求和( sum() )
有聚合函数意味着分组( GROUP BY )

 

  • 08)查询「李」姓老师的数量

 

四.思维导图

 


             好啦今天就到这里了哦!!!希望能帮到你哦!!! 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/328013.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

docker部署kibana

1,简介 官网 kibana 2,安装docker 参考 linux安装docker 3,准备 Kibana 配置文件 # 进入主节点配置文件目录 cd /export/server/docker/kibana/config # 编辑单机版配置文件 vi kibana.ymlkibana.yml内容 # 主机地址,可以是…

BUUCTF--actf_2019_babyheap1

这题看名字就知道是堆题,先看保护: 保护除了PIE全开,黑盒测试: 题目提供增删查,没有改。看看IDA中代码逻辑: 逻辑跟我前面做的一题极为相似,就不过多分析。 这是free: 因为题目不能…

八大算法排序@快速排序、递归版本一(C语言版本)

目录 快速排序版本一概念算法思想一二三 快排步骤代码实现时间复杂度空间复杂度特性总结 快速排序版本一 概念 快速排序(Quicksort)是一种高效的排序算法,它是由英国计算机科学家 Tony Hoare 在1960年提出的。快速排序是基于分治&#xff08…

修改对象的行为和值(代理)

文章目录 前言一、复制一个对象二、代理对象重点来了 总结 前言 最近遇到一个需求,需要在某个位置,统一处理对象的一些属性值: 方案有两种: 直接复制一份,将属性覆盖后,返回一个新对象搞一个代理类,代理这个对象,修改对象的原有行为和值,从而达到修改属性值的目的…

【GoLang入门教程】Go语言几种标准库介绍(四)

编程语言的未来? 文章目录 编程语言的未来?前言几种库fmt库 (格式化操作)关键函数:示例 Go库标准库第三方库示例 html库(HTML 转义及模板系统)主要功能:示例 总结专栏集锦写在最后 前言 上一篇,我们介绍了debug、enco…

关于“Python”的核心知识点整理大全65

目录 20.2.19 设置 SECRET_KEY 20.2.20 将项目从 Heroku 删除 注意 20.3 小结 附录 A 安装Python A.1.1 确定已安装的版本 A.1.2 在 Linux 系统中安装 Python 3 A.2 在 OS X 系统中安装 Python A.2.1 确定已安装的版本 A.2.2 使用 Homebrew 来安装 Python 3 注意 …

基于商品列表的拖拽排序后端实现

目录 一:实现思路 二:实现步骤 二:实现代码 三:注意点 一:实现思路 后台实现拖拽排序通常需要与前端进行配合,对商品的列表拖拽排序,前端需要告诉后端拖拽的元素和拖动的位置。 这里我们假…

Matlab三维绘图

绘制三维图plot3 t0:pi/50:10*pi; xsin(t); ycos(t); zt; plot3(x,y,z); 产生栅格数据点meshgrid 这个接口在绘制三维图像里面相当重要,很多时候要将向量变成矩阵才能绘制三维图。 x0:0.5:5; y0:1:10; [X,Y]meshgrid(x,y); plot(X,Y,o); x和y是向量,…

RocketMQ单机部署完整学习笔记

文章目录 前言一、RocketMQ是什么?二、使用步骤1.安装MQ1.安装JDK2.安装mq3.MQ配置(核心) 2.搭建可视化dashboard1.下载源码2.修改配置3.启动 3.整合java1.生产者2.消费者3.启动生产者4.启动消费者5.dashboard添加消费组 三、总结全部的配置 前言 本文是基于4.X版本…

LeetCode 2221. 数组的三角和

文章目录 1. 题目 2. 解题 1. 题目 给你一个下标从 0 开始的整数数组 nums ,其中 nums[i] 是 0 到 9 之间(两者都包含)的一个数字。 nums 的 三角和 是执行以下操作以后最后剩下元素的值: num…

I.MX6ULL开发笔记(二)——硬件外设操作

0x01 点亮第一个RGB灯 在文章http://t.csdnimg.cn/EGWt9中有介绍Linux下文件目录,那么在Linux系统下,RGB灯也是一个设备,所以我们需要到/sys目录下去操作这个设备。 之后,我们进入到class目录,这里挂载着开发板上的外…

Mongodb删除操作中字符序对结果的影响

本文还是要从删除操作的语法说起。 db.collection.deleteMany(<filter>,{writeConcern: <document>,collation: <document>,hint: <document|string>} ) 删除语法中&#xff0c;可以指定数据写入策略&#xff0c;字符序和使用的索引字段。 字符序&a…