【MySQL】——数据查询操作

💻博主现有专栏:

                C51单片机(STC89C516),c语言,c++,离散数学,算法设计与分析,数据结构,Python,Java基础,MySQL,linux,基于HTML5的网页设计及应用,Rust(官方文档重点总结),jQuery,前端vue.js,Javaweb开发,Python机器学习等
🥏主页链接:

                Y小夜-CSDN博客

目录

🎯语句格式

🎯单表查询

🎃查仅涉及一个表

✨选择表中若干列

✨选择表中的若干元组

🎃Order by子句

🎃聚集函数

🎃group by字句

🎯连接查询

🎃等值与非等值连接查询

🎃自身连接

🎃外连接

🎃多表连接

🎯嵌套查询

🎯集合查询

🎯基于派生表的查询

🎯SELECT语句的一般形式

🎃目标列表达式的可选格式


🎯语句格式

   SELECT [ALL|DISTINCT] <目标列表达式>[,<目标列表达式>]

   FROM <表名或视图名>[,<表名或视图名> ]…|(SELECT 语句)   

        [AS]<别名>

[ WHERE <条件表达式> ]

[ GROUP BY <列名1> [ HAVING <条件表达式> ] ]

[ ORDER BY <列名2> [ ASC|DESC ] ];

  • SELECT子句:指定要显示的属性列
  • FROM子句:指定查询对象(基本表或视图)
  • WHERE子句:指定查询条件
  • GROUP BY子句:对查询结果按指定列的值分组,该属性列值相等的元组为一个组。通常会在每组中作用聚集函数。
  • HAVING短语:只有满足指定条件的组才予以输出
  • ORDER BY子句:对查询结果表按指定列值的升序或降序排序

🎯单表查询

🎃查仅涉及一个表

✨选择表中若干列

查询全部列

选出所有属性列:

  • 在SELECT关键字后面列出所有列名
  • 将<目标列表达式>指定为  *

查询经过计算的值:

  • SELECT子句的<目标列表达式>不仅可以为表中的属性列,也可以是表达式

✨选择表中的若干元组

消除取值重复的行

  •  如果没有指定DISTINCT关键词,则缺省为ALL
  • 指定DISTINCT关键词,去掉表中重复的行

确定集合:

  • 谓词:IN <值表>,  NOT IN <值表>  

字符匹配:

  • 谓词: [NOT] LIKE  ‘<匹配串>’  [ESCAPE ‘ <换码字符>’]

涉及到控制查询:

  • 谓词: IS NULL 或 IS NOT NULL  “IS” 不能用 “=” 代替

多重条件查询

  • 逻辑运算符:AND和 OR来连接多个查询条件  
  • AND的优先级高于OR
  •  可以用括号改变优先级

🎃Order by子句

  • 可以按一个或多个属性列排序
  • 升序:ASC;降序:DESC;缺省值为升序
  • 对于空值,排序时显示的次序由具体系统实现来决定

🎃聚集函数

统计元组个数  :

  • COUNT(*) 统计一列中值的个数      
  • COUNT([DISTINCT|ALL] <列名>)

计算一列值的总和(此列必须为数值型):

  • SUM([DISTINCT|ALL] <列名>)  

  计算一列值的平均值(此列必须为数值型):

  • AVG([DISTINCT|ALL] <列名>)

求一列中的最大值和最小值  :

  • MAX([DISTINCT|ALL] <列名>)     
  • MIN([DISTINCT|ALL] <列名>)

🎃group by字句

GROUP BY子句分组:

细化聚集函数的作用对象 

  • 如果未对查询结果分组,聚集函数将作用于整个查询结果
  • 对查询结果分组后,聚集函数将分别作用于每个组
  • 按指定的一列或多列值分组,值相等的为一组

HAVING短语与WHERE子句的区别:

  • 作用对象不同 WHERE子句作用于基表或视图,从中选择满足条件的元组
  • HAVING短语作用于组,从中选择满足条件的组。

🎯连接查询

连接查询:同时涉及两个以上的表的查询

连接条件或连接谓词:用来连接两个表的条件     

  • 一般格式: [<表名1>.]<列名1>  <比较运算符>  [<表名2>.]<列名2>
  • [<表名1>.]<列名1> BETWEEN [<表名2>.]<列名2> AND [<表名2>.]<列名3>

连接字段:连接谓词中的列名称

连接条件中的各连接字段类型必须是可比的,但名字不必相同

🎃等值与非等值连接查询

等值连接:连接运算符为=

方法:

  • 嵌套循环法(NESTED-LOOP)
  • 排序合并法(SORT-MERGE)
  • 索引连接(INDEX-JOIN)

自然连接:

        一条SQL语句可以同时完成选择和连接查询,这时WHERE子句是由连接谓词和选择谓词组成的复合条件。

执行过程:

  • 先从SC中挑选出Cno='2'并且Grade>90的元组形成一个中间关系
  • 再和Student中满足连接条件的元组进行连接得到最终的结果关系

🎃自身连接

  • 自身连接:一个表与其自己进行连接
  • 需要给表起别名以示区别
  • 由于所有属性名都是同名属性,因此必须使用别名前缀

🎃外连接

外连接与普通连接的区别:

  • 普通连接操作只输出满足连接条件的元组
  • 外连接操作以指定表为连接主体,将主体表中不满足连接条件的元组一并输出  

左外连接:

  • 列出左边关系中所有的元组

 右外连接:

  • 列出右边关系中所有的元组

🎃多表连接

多表连接:两个以上的表进行连接

        在建立数据表时,如果一个表与多个表联接,那么这一个表中的字段必须是“数字”数据类型,而多个表中的相同字段必须是主键,而且是“自动编号”数据类型。 否则,很难联接成功。 代码嵌套快速方法:如,想连接五个表,则只要在连接四个表的代码上加一个前后括号(前括号加在FROM的后面,后括号加在代码的末尾即可),然后在后括号后面继续添加“INNER JOIN 表名X ON 表1.字段号=表X.字段号”代码即可,这样就可以无限联接数据表了。

🎯嵌套查询

嵌套查询概述:

  • 一个SELECT-FROM-WHERE语句称为一个查询块
  • 将一个查询块嵌套在另一个查询块的WHERE子句或HAVING短语的条件中的查询称为嵌套查询
  • 上层的查询块称为外层查询或父查询
  • 下层查询块称为内层查询或子查询
  • SQL语言允许多层嵌套查询:即一个子查询中还可以嵌套其他子查询
  • 子查询的限制:不能使用ORDER BY子句

嵌套查询可分成不相关子查询和相关子查询两类。

  • 不相关子查询的查询条件不依赖于父查询,一般使用谓词IN。
  • 相关子查询的查询条件依赖于外层父查询的某个属性值,一般使用谓词EXISTS。

同样一个查询,既可以用不相关子查询实现,也可以用相关子查询实现,也可以用连接查询实现。  

🎯集合查询

集合操作的种类

  • 并操作UNION
  • 交操作INTERSECT
  • 差操作EXCEPT
  • 参加集合操作的各查询结果的列数必须相同;对应项的INTERSECT

数据类型也必须相同,列名可以不同

UNION:将多个查询结果合并起来时,系统自动去掉重复元组

UNION ALL:将多个查询结果合并起来时,保留重复元组

🎯基于派生表的查询

子查询不仅可以出现在WHERE子句中,还可以出现在FROM子句中,这时子查询生成的临时派生表(Derived Table)成为主查询的查询对象

例子:

查询所有选修了1号课程的学生姓名,可以用如下查询完成:  

  SELECT Sname  

  FROM     Student,                      

(SELECT Sno FROM SC WHERE Cno=' 1 ') AS SC1    

WHERE  Student.Sno=SC1.Sno;

🎯SELECT语句的一般形式

 SELECT [ALL|DISTINCT]

     <目标列表达式> [别名] [ ,<目标列表达式> [别名]] …  FROM

    <表名或视图名> [别名]

                [ ,<表名或视图名> [别名]] …

                |(<SELECT语句>)[AS]<别名>

 [WHERE <条件表达式>]

 [GROUP BY <列名1>[HAVING<条件表达式>]]

 [ORDER BY <列名2> [ASC|DESC]];

🎃目标列表达式的可选格式

目标列表达式格式

(1) *

(2) <表名>.*

(3) COUNT([DISTINCT|ALL]* )

(4) [<表名>.]<属性列名表达式>[,<表名>.]<属性列名表达式>]…

其中<属性列名表达式>可以是由属性列、作用于属性列 的聚集函数和常量的任意算术运算(+,-,*,/)组成的 运算公式

🎃聚集函数的一般形式

        COUNT 

          SUM

          AVG        ——————》([DISTINCT|ALL] <列名>)

          MAX

           MIN

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

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

相关文章

一主双从redis+哨兵模式以及通过Ansible+Shell快速部署redis哨兵模式

目录 一.主redis配置 1.解压并进行编译安装 2.为redis创建软链接和service管理方便启动 3.修改redis的配置文件 二.配置备redis 三.主redis上查看集群状态 1.主redis登录上去查看状态并且创建数据用于验证同步性 2.备redis查看数据是否同步过来 四.模拟测试 1.主redi…

stm32——GPIO学习

对于许多刚入门stm32的同学们来说&#xff0c;GPIO是我们的第一课&#xff0c;初出茅庐的我们会对GPIO的配置感到疑惑不解&#xff0c;也是劝退我们的第一课&#xff0c;今天我们就来一起学习一下stm32的GPIO&#xff0c;提振一下信心。好的&#xff0c;发车了小卷卷们&#xf…

CDR2024版本免费Windows10包含免费激活码序列号

CorelDRAW2024作为一款专业的平面设计软件&#xff0c;专注于矢量图形编辑与排版&#xff0c;其强大的功能和丰富的工具集为设计师们提供了无限可能。在最新版本中&#xff0c;CorelDRAW引入了一系列令人瞩目的新功能&#xff0c;进一步提升了用户体验和工作效率。以下是对Core…

【css】select实现placeholder效果

场景&#xff1a;使用select下拉选择框的时候&#xff0c;需要像其他控件一样提示默认信息。 问题&#xff1a;表单控件select没有placeholder属性。 解决方案&#xff1a;通过css实现&#xff0c;不需要js <style>select > option[disabled]{ color:#999;cursor: n…

【springMVC】@RequestMapping的作用

1.作用 将指定 URL 的请求绑定到一个特定的方法或类上&#xff0c;从而实现对请求的处理和响应。 RequestMapping注解只能出现在类上或者方法上。 2.value属性 Ant风格的value&#xff08;模糊匹配路径&#xff09;&#xff1a; 1&#xff09;?&#xff0c;代表任意一个字符 …

用docker方式安装openGauss数据库的事项记录

文章目录 &#xff08;一&#xff09;背景&#xff08;二&#xff09;安装&#xff08;2.1&#xff09;安装docker&#xff08;2.2&#xff09;安装openGauss &#xff08;三&#xff09;运行&#xff08;3.1&#xff09;运行openGauss镜像&#xff08;3.2&#xff09;连接open…

30 OpenCV 点多边形测试

文章目录 点多边形测试pointPolygonTest示例 点多边形测试 pointPolygonTest pointPolygonTest( InputArray contour,// 输入的轮廓 Point2f pt, // 测试点 bool measureDist // 是否返回距离值&#xff0c;如果是false&#xff0c;1表示在内面&#xff0c;0表示在边界上&a…

定时器使用

最近工作中遇到了一个场景&#xff0c;需要定时请求后台数据并更新到界面上&#xff0c;在C#中&#xff0c;有三种定时器&#xff1a; 1.System.Timers.Timer 2.System.Threading.Timer 3.System.Windows.Threading.DispatcherTimer 1&#xff0c;2两种方式差不多&#xff0c;都…

白嫖游戏指南,Epic喜加二:《INDUSTRIA》《LISA: Definitive Edition》

前言 Epic喜加二&#xff1a;《INDUSTRIA》《LISA: Definitive Edition》《INDUSTRIA》简介&#xff1a; 《LISA: Definitive Edition》简介&#xff1a; 前言 接下来有时间会分享一些游戏相关可以白嫖的资源&#xff0c;包括游戏本体、游戏素材资源等等。 有需要的小伙伴可以…

ABAP json解析使用引用代替预定义数据结构

背景&#xff1a;在解析JSON数据时&#xff0c;通常会事先为定义相应的ABAP数据结构。但是&#xff0c;当遇到一些结构纵深较为复杂的情况时&#xff0c;会比较麻烦。 处理&#xff1a;使用引用类型来定义结构中的纵深部分来达到“省事”的目的&#xff0c;缺点在于访问时需要使…

JavaScript基础学习(7)

⭐ 作者简介&#xff1a;码上言 ⭐ 代表教程&#xff1a;Spring Boot vue-element 开发个人博客项目实战教程 ⭐专栏内容&#xff1a;个人博客系统 ⭐我的文档网站&#xff1a;http://xyhwh-nav.cn/ ⭐微信公众号&#xff1a;码上言 文章目录 操作符1. 乘性操作符1.1 乘法…

零拷贝的几种实现

mmapwrite() sendfile系统调用 sendfile SG-DMA

Python 中range和xrange有什么区别

Python 中range和xrange有什么区别 在Python中&#xff0c;range 和 xrange 是两个用于生成数字序列的函数&#xff0c;但它们之间有一些区别。让我详细解释一下&#xff1a; range 函数&#xff1a; range 函数用于生成一个数字序列&#xff0c;返回一个列表对象。语法&…

Linux I2C(二) - I2C软硬件架构

1&#xff0c;I2C的总线拓扑 2&#xff0c;I2C S/W topology linux kernel I2C framework使用如下的软件拓扑抽象I2C硬件&#xff08;我们可以一起领会一下其中的“设备模型”思想&#xff09;&#xff1a; 1&#xff09;platform bus&#xff08;/sys/bus/platform&#xff0…

七、四个步骤实现FFmpeg推流播放实战

目录 1.Windows安装已经集成nginx-http-flv-module的nginx, 2.nginx.conf配置文件 3.ffmpeg推流 4.v

jmeter分布式压力测试搭建

配置master&#xff08;controller&#xff09; 配置jmeter.properties文件 remote_hostsxxx:1099,xxx:1099 #remote_hostslocalhost:1099,localhost:2010 # RMI port to be used by the server (must start rmiregistry with same port) server_port1099 server.rmi.ssl.dis…

excel文件导入dbeaver中文乱码

1.将excel文件进行另存为&#xff0c;保存类型选择【CSV】 2.选择【工具】–>【web选项】–> 【编码】–> 【简体中文&#xff08;GB18030&#xff09;】 3.在DBeaver进行数据导入 直接导入应该就可以&#xff0c;如果不行的话按下面处理。 选择【导入数据——选择cs…

软考 - 系统架构设计师 - 基于口令的认证方式和基于公钥体系的认证方式

基于口令的认证方式和基于公钥体系的认证方式在网络安全领域都有广泛的应用&#xff0c;但它们各自具有不同的特点和使用场景。 基于口令的认证方式 基于口令的认证方式是一种传统的身份认证技术&#xff0c;用户通过输入预设的密码来验证身份。这种方式实现简单&#xff0c;成…

Python函数小知识

目录 一、函数的定义和调用 二、函数参数 三、函数作用域 四、递归函数和匿名函数 一、函数的定义和调用 def 函数名(参数): 自定义函数可以分为有参函数和无参函数 。 函数的作用&#xff1a; 在Python中定义函数可以提高代码的复用率&#xff0c;避免重复的代码&#xff0c;…