[MySQL]视图索引以及连接查询案列

news2024/11/17 19:37:39

目录

1.视图

1.1视图是什么

 1.2视图的作用

1.3操作

1.3.1创建视图

1.3.2视图的修改

 1.3.3删除视图

 1.3.4查看视图

 2.索引

2.1什么是索引

2.2为什么要使用索引

 2.3索引的优缺点

2.3.1优点

2.3.2缺点

 2.4索引的分类

 3.连接查询案列

 4.思维导图


1.视图

1.1视图是什么

视图(View)是数据库中的虚拟表,是由一个或多个基本表(或其他视图)的行或列组成的。视图并不在数据库中占用存储空间,并且可以提供一种逻辑上的数据组织方式,将数据按照某种条件过滤、划分或组合,以方便用户查询和使用数据。

含义:

虚拟表,和普通表一样使用

 1.2视图的作用

  1. 数据安全性:视图可以限制用户对数据的访问权限。通过只向用户开放特定的视图,可以隐藏实际存储数据的表和列,保护敏感信息的安全性。视图还可以根据用户的角色和权限,提供不同级别的数据访问控制。

  2. 数据的逻辑组织和定制:视图可以对基本表进行逻辑上的组织和定制,以满足用户的特定需求。通过视图,可以对数据进行过滤、排序、聚合和连接等操作,将数据以一种用户友好的方式展示出来,减少了用户对底层数据结构的了解和操作。

  3. 数据的简化和抽象:视图可以简化复杂的查询操作,将一系列的数据操作组合在一起提供给用户,使用户能够更方便地进行数据的查询和分析。通过视图,用户可以从多个表中获取所需的信息,而无需编写复杂的JOIN和WHERE子句。

  4. 逻辑数据独立性:视图可以提供逻辑数据独立性,使应用程序和数据库之间的关联变得松耦合。如果底层表结构发生变化,只需调整视图的定义即可,而不需要修改应用程序中使用视图的相关代码。

  5. 性能提升:视图可以提供对常用查询的优化,通过将查询的结果存储在视图中,可以减少复杂的计算和数据访问操作,提高查询的性能。

1.3操作

1.3.1创建视图

创建视图语法:

carete view 视图名

as

查询语句

1.3.2视图的修改

方式一:

create or replace view 视图名

as

查询语句

方式二:

alter view 视图名

as

查询语句

 1.3.3删除视图

删除视图的语法:

drop view 视图名,视图名........

 1.3.4查看视图

查看视图相关字段

DESC 视图名

查看视图相关语句

SHOW CREATE VIEW 视图名 

 2.索引

2.1什么是索引

索引是数据库中用于加快数据检索速度的一种数据结构。它类似于书籍的目录,通过在关键字和对应数据位置之间建立的映射关系,可以帮助数据库系统更快地定位和访问特定的数据记录。索引通常是在数据库表的一列或多列上创建的,以提高对这些列的查询速度。

2.2为什么要使用索引

索引是一种特殊的数据库结构,由数据表中的一列或多列组合而成,可以用来快速查询数据表中某一特定值的记录。

 2.3索引的优缺点

2.3.1优点

  1. 提高查询速度:索引可以大大加快数据的检索速度,特别是在大型数据表中。
  2. 加速排序:使用索引可以加速ORDER BY子句的查询,使数据按照特定的列进行快速排序。
  3. 加速连接:在进行表的连接操作时,如果连接的列上有索引,可以提高连接的速度。
  4. 提高唯一性约束:可以创建唯一索引来强制单个列或多列的唯一性约束。

2.3.2缺点

  1. 占用存储空间:索引需要额外的存储空间,这会增加数据库的存储成本。
  2. 维护成本:在数据插入、更新和删除时,索引的维护也会增加相应的开销,可能会影响性能。
  3. 复杂查询的代价:在执行查询时,如果使用了多个索引,可能需要对多个索引进行查找和合并,这可能会导致查询性能下降。
  4. 索引失效:当数据库中的数据量较小时,使用索引可能会导致优化器不选择索引,反而影响查询性能。
  5. 索引选择错误:选择不当的索引可能导致查询性能降低,需要权衡查询需求与索引选择。

 2.4索引的分类

  1. 单列索引(Single-Column Index):针对单个列创建的索引。最为常见的索引类型,可用于加快单列查询速度。

  2. 复合索引(Composite Index):针对多个列组合创建的索引。通过在多个列上创建索引可以提高复合条件的查询速度,同时也提供了对这些列的单列查询的优化。

  3. 唯一索引(Unique Index):确保索引列的值全部唯一的索引。用于实施唯一性约束,防止表中出现重复的值。

  4. 主键索引(Primary Key Index):主键在数据库表中起到唯一标识记录的作用,数据库系统通常会对主键列自动创建主键索引,以确保主键的快速检索。

  5. 外键索引(Foreign Key Index):在包含外键的列上创建的索引,用于加快外键关联表之间的连接和查询操作。

  6. 全文索引(Full-Text Index):针对文本类型的列进行的特殊索引,用于支持全文搜索和匹配。

  7. 聚集索引(Clustered Index):数据行的物理顺序与索引的逻辑顺序一致的索引。在聚集索引中,索引本身就是数据的排列顺序,因此表中的数据行实际上就是按照这个顺序进行存储的。

  8. 非聚集索引(Non-Clustered Index):索引中的顺序与数据行的物理存储不同。在非聚集索引中,索引和数据行是分开存储的,索引的叶子节点中存储的是指向数据行的指针或引用。

 3.连接查询案列

01)查询" 01 "课程比" 02 "课程成绩高的学生的信息及课程分数

SELECT
    * 
FROM
    t_mysql_student s,
    ( SELECT * FROM t_mysql_score WHERE cid = '01' ) t1,
    ( SELECT * FROM t_mysql_score WHERE cid = '02' ) t2 
WHERE
    s.sid = t1.sid 
    AND t1.sid = t2.sid 
    AND t1.score > t2.score

 查询结果

02)查询同时存在" 01 "课程和" 02 "课程的情况

SELECT
    s.*,
    ( CASE WHEN t1.cid = '01' THEN t1.score END ) 语文,
    ( CASE WHEN t2.cid = '02' THEN t2.score END ) 数学 
FROM
    t_mysql_student s,
    ( SELECT * FROM t_mysql_score WHERE cid = '01' ) t1,
    ( SELECT * FROM t_mysql_score WHERE cid = '02' ) t2 
WHERE
    s.sid = t1.sid 
    AND t1.sid = t2.sid

 查询结果


03)查询存在" 01 "课程但可能不存在" 02 "课程的情况(不存在时显示为 null )

SELECT
    * 
FROM
    ( SELECT * FROM t_mysql_score WHERE cid = '01' ) t1
    LEFT JOIN ( SELECT * FROM t_mysql_score WHERE cid = '02' ) t2 ON t1.sid = t2.sid;
SELECT
    s.*,
    ( CASE WHEN t1.cid = '01' THEN t1.score END ) 语文,
    ( CASE WHEN t2.cid = '02' THEN t2.score END ) 数学 
FROM
    t_mysql_student s
    INNER JOIN ( SELECT * FROM t_mysql_score WHERE cid = '01' ) t1 ON s.sid = t1.sid
    LEFT JOIN ( SELECT * FROM t_mysql_score WHERE cid = '02' ) t2 ON t1.sid = t2.sid; 

 查询结果


04)查询不存在" 01 "课程但存在" 02 "课程的情况

SELECT
    s.*,
    ( CASE WHEN sc.cid = '01' THEN sc.score END ) 语文,
    ( CASE WHEN sc.cid = '02' THEN sc.score END ) 数学 
FROM
    t_mysql_student s,
    t_mysql_score sc 
WHERE
    s.sid = sc.sid 
    AND s.sid NOT IN ( SELECT sid FROM t_mysql_score WHERE cid = '01' ) 
    AND sc.cid = '02'

查询结果


05)查询平均成绩大于等于 60 分的同学的学生编号和学生姓名和平均成绩

SELECT
    s.sid,
    s.sname,
    ROUND( avg( sc.score ), 2 ) n 
FROM
    t_mysql_student s
    LEFT JOIN t_mysql_score sc ON s.sid = sc.sid 
GROUP BY
    s.sid,
    s.sname 
HAVING
    n >= 60

查询结果


06)查询在t_mysql_score表存在成绩的学生信息

SELECT
    s.sid,
    s.sname 
FROM
    t_mysql_student s
    LEFT JOIN t_mysql_score sc ON s.sid = sc.sid 
GROUP BY
    s.sid,
    s.sname

查询结果


07)查询所有同学的学生编号、学生姓名、选课总数、所有课程的总成绩(没成绩的显示为 null )

SELECT
    s.sid,
    s.sname,
    count( sc.score ) 选课总数,
    sum( sc.score ) 总成绩 
FROM
    t_mysql_student s
    LEFT JOIN t_mysql_score sc ON s.sid = sc.sid 
GROUP BY
    s.sid,
    s.sname

查询结果

 4.思维导图

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

代码随想录-刷题第四十九天

121. 买卖股票的最佳时机 题目链接:121. 买卖股票的最佳时机 思路:动态规划五步曲 dp[i][0] 表示第i天持有股票所得最多现金,dp[i][1] 表示第i天不持有股票所得最多现金。 一开始现金是0,那么加入第i天买入股票,现金…

深入了解 RDD

深入了解 RDD 案例 明确需求: 在访问日志中,统计独立IP数量 TOP10 查看数据结构: IP,时间戳,Http,Method,Url…… 明确编码步骤 取出IP,生成一个只有IP的数据集简单清洗统计IP出现…

Tomcat Notes: Deployment File

This is a personal study notes of Apache Tomcat. Below are main reference material. - YouTube Apache Tomcat Full Tutorial,owed by Alpha Brains Courses. https://www.youtube.com/watch?vrElJIPRw5iM&t801s 1、Tomcat deployment1.1、Two modes of …

数据结构与算法教程,数据结构C语言版教程!(第二部分、线性表详解:数据结构线性表10分钟入门)九

第二部分、线性表详解:数据结构线性表10分钟入门 线性表,数据结构中最简单的一种存储结构,专门用于存储逻辑关系为"一对一"的数据。 线性表,基于数据在实际物理空间中的存储状态,又可细分为顺序表&#xff…

Java 基础知识点1 (含面试题)

本次Java 知识点主要是关于SE的相关基础,同时也包含了数据结构中的一些API,例如Set,List,Map等,最后也附上了相关重要的面试题,可供大家学习与参考! 目录 重要知识点数据结构API面试题 重要知识点 Java 是一门面向对象…

linux下超级程序!在linux界面实现类图像化界面的操作体验!

linux下超级程序!在linux界面实现类图像化界面的操作体验! 本期带来一个超级程序!在linux界面实现类图像化界面的操作体验。具体功能代码如下: 1500行完整代码想要完成部署,只需在本地创建一个LinuxGJ.sh的文件,然后…

传感数据分析——高通滤波与低通滤波

传感数据分析——高通滤波与低通滤波 文章目录 传感数据分析——高通滤波与低通滤波前言一、运行环境二、Python实现总结 前言 对于传感信号而言,我们可以提取其中的高频信息和低频信息,低频信息往往是信号的趋势,高频信息往往是一些突变或异…

构建自己的私人GPT

创作不易,请大家多鼓励支持。 在现实生活中,很多人的资料是不愿意公布在互联网上的,但是我们又要使用人工智能的能力帮我们处理文件、做决策、执行命令那怎么办呢?于是我们构建自己或公司的私人GPT变得非常重要。 一、本地部署…

win10下vscode+cmake编译C代码操作详解

0 工具准备 1.Visual Studio Code 1.85.1 2.cmake 3.24.01 前言 当我们只有一个.c文件时直接使用vscodeCode Runner插件即可完成编译,如果我们的工程很复杂包含多个.c文件时建议使用cmake来生成对应的make,指导编译器完成编译,否则会提示各…

数字图像处理(图像灰度变换、图像直方图及均衡、图像中值滤波、图像空域锐化增强、图像频域滤波)

数字图像处理(图像灰度变换、图像直方图及均衡、图像中值滤波、图像空域锐化增强、图像频域滤波) 目录 1 图像灰度变换 1.1 灰度线性变换 1.2 图像二值化 1.3 负象变换 1.4 灰度非线性变换 1.5 程序设计流程图 2 图像直方图及均衡 2.1 直方图 2…

无心剑七绝《高斯黎曼》

七绝高斯黎曼 高耸云端四海惊 斯人伟绩震豪英 黎霞璀璨通灵处 曼妙方程万世名 2024年1月6日 平水韵八庚平韵 《七绝高斯黎曼》是无心剑所作的一首以数学家为主题的七言绝句。全诗巧妙地将两位杰出的数学家——高斯(Carl Friedrich Gauss)与黎曼&#…

大模型机器人原理解析:如何从RT/RT2、Berkeley Gello到发展到斯坦福Mobile ALOHA、Google家务机器人

前言 23年7月,我在朋友圈评估Google的RT2说道: “大模型正在革新一切领域啊,超帅,通过大模型不仅能理解“人话”,还能对“人话”进行推理,并转变为机器人能理解的指令,从而分阶段完成任务。回…

express框架

目录 一、express介绍二、express 使用2.1 express下载2.2 express初体验 三、express 路由3.1 路由的使用3.2 获取参数3.3 获取路由参数 四、express响应设置五、express中间件5.1 什么是中间件5.2 中间件的作用5.3 中间件的类型5.3.1 定义全局中间件5.3.2 多个全局中间件5.3.…

协程池与新脚本语言

今天的主人公名为——Melang。 这是一款使用C语言开发的“新”的脚本语言,然而其已经默默问世了6年之久。 下面笔者就带你走进Melang world。 What is Melang Melang是一款协程并发脚本语言。它是一款解释型,而非编译型语言。 在Melang中&#xff…

html中的form表单以及相关控件input、文本域、下拉select等等的详细解释 ,点赞加关注持续更新~

文章目录 表单创建表单forminput 标签input标签的value属性设置input标签格式单选框多选框上传文件下拉菜单文本域设置文本域格式label 标签按钮 表单 作用&#xff1a;收集用户信息。 使用场景&#xff1a; 登录页面注册页面搜索区域 创建表单form <form action".…

实战环境搭建-linux下安装jdk1.8

查看安装jdk版本信息,主要是怕之前有遗漏的,或者安装失败的java rpm -qa | grep java 显示如下信息: 卸载: rpm -e --nodeps java-1.7.0-openjdk-1.7.0.261-2.6.22.2.el7_8.x86_64 rpm -e --nodeps java-1.8.0-openjdk-1.8.0.262.b10-1.el7.x86_64 还有一些其他的命令…

MATLAB插值函数

一、MATLAB插值函数概览 1&#xff09;本节重点介绍的插值函数 MATLAB插值函数适用情况基础句式interp1 函数interp1 主要用于一维数据的插值interp1(x, y, x_interp, ‘linear’); 其中 x 和 y 是已知数据点&#xff0c;x_interp 是要插值的目标点。interp2 函数interp2 用于…

【STM32】PWR电源控制

1 PWR简介 PWR&#xff08;Power Control&#xff09;电源控制 PWR负责管理STM32内部的电源供电部分&#xff0c;可以实现可编程电压监测器和低功耗模式的功能 可编程电压监测器&#xff08;PVD&#xff09;可以监控VDD电源电压&#xff0c;当VDD下降到PVD阀值以下或上升到P…

回首2023,期待2024!

2023&#xff0c;在改变中到来 2023年1月1日&#xff0c;我从成都冷清的学校回到了哈尔滨的老家&#xff0c;开始了保研之前的最后一个寒假 当时的目标是将之前的科研理论转化为实际&#xff0c;生产出一篇sci&#xff0c;助力保研加分 星移斗转&#xff0c;事与愿违&#x…

从零实现CLIP模型

1. 引言 CLIP代表语言图像对比预训练模型&#xff0c;是OpenAI于2021年开发的一个深度学习模型。CLIP模型中图像和文本嵌入共享相同的潜在特征空间&#xff0c;从而能够在两种模式之间直接进行对比学习。这是通过训练模型使相关的图像和文本更紧密地结合在一起&#xff0c;同时…