首页 / Mysql / MySQL单表查询实例详解

MySQL单表查询实例详解

1、准备数据 以下操作将在该表中进行2、查询语法 3、执行顺序 虽然查询的书写语法是上面那样的,但是其内部执行顺序却有些不太一样。

1、准备数据

以下操作将在该表中进行

2、查询语法

3、执行顺序

虽然查询的书写语法是上面那样的,但是其内部执行顺序却有些不太一样。

   1.通过from找到将要查询的表

   2.where规定查询条件,在表记录中逐行进行查询并筛选出符合规则的记录

   3.将查到的记录进行字段分组group by,如果没有进行分组,则默认为一组

   4.将分组得到的结果进行having筛选,可使用聚和函数(where时不可使用聚合函数)

   5.执行select准备打印

   6.执行distinct对打印结果进行去重

   7.执行ordery by对结果进行排序

   8.执行limit对打印结果的条数进行限制

4、select

   select主要复负责打印相关的工作

4.1 全部查询

   使用select * from 表名可拿到该表下全部的数据

   以下示例将展示使用全部查询拿到student表中所有记录

4.2 字段查询

   使用select 字段名1,字段名2 from 表名可拿到特定字段下相应的数据

   以下示例将展示使用字段查询拿到每个学生的HTMLCSSJS成绩

4.3 as 别名

   使用select 字段名1 as 别名1, 字段名2 as 别名2 from 表名可将查询到的记录字段修改一个别名

   以下示例将展示修改name字段为姓名,修改gender字段为性别,修改age字段为年龄的操作

4.4 distinct

   使用select distinct(字段名1, 字段名2) from 表名可将查询到的记录做一个取消重复的操作

   以下示例将展示使用去重功能来看有多少个小组

4.5 四则运算

   查询结果可进行四则运算,以下示例将展示拿到每个同学三科总分的操作

4.6 显示格式

   使用concat()可将查询结果与任意字符串进行拼接

   使用concat_ws()可指定连接符进行拼接,第一个参数是连接符

5、where

   where条件是查询的第一道坎,能有效过滤出我们想要的任意数据

5.1、比较运算

   使用比较运算符> < >= <= !=进行查询

   以下示例将展示使用where过滤出js成绩大于80分的同学

5.2、逻辑运算

   使用and or not可进行逻辑运算与多条件查询

   以下示例将展示使用where多条件查询过滤出各科成绩都大于80分的同学

5.3、成员运算

   in可以在特定的值中进行获取,如in(80,90,100)则代表只取80或者90或者100的这几条记录。

   以下示例将展示只取第一组first以及第二组second学生的个人信息

5.4、between and

   between and也是取区间的意思,

   以下示例将展示使用between and过滤出Js成绩大于等于60并且小于80的同学

5.5、like

   like是模糊查询,其中%代表任意多个字符(类似于贪婪匹配的通配符.*),_代表任意一个字符(类似于非贪婪匹配的通配符.*?)。

   以下示例将展示使用like/%匹配出姓名以k开头的所有同学的名字

   以下示例将展示使用like/_匹配出姓名以k开头并整体长度为3的同学的名字

5.6、正则匹配

   使用RegExp可进行正则匹配,以下示例将展示使用正则匹配出名字中带有k的所有同学姓名

6、group by

   分组行为发生在where条件之后,我们可以将查询到的记录按照某个相同字段进行归类,一般分组都会配合聚合函数进行使用。

   需要注意的是select语句是排在group by条件之后的,因此聚合函数也能在select语句中使用。

6.1、基本使用

   以下示例将展示对hoc_group字段进行分组。

   我们按照hoc_group字段进行分组,那么select查询的字段只能是hoc_group字段,想要获取组内的其他字段相关信息,需要借助函数来完成

   如果不使用分组,则会产生重复的信息

6.2、group_concat

   用什么字段名进行分组,在select查询时就只能查那个用于分组的字段,查询别的字段会抛出异常,会提示sql_mode异常。

   我们将Js成绩大于80分的同学筛选出来并且按照gender字段进行分组,此外我们还想查看其所有满足条件同学的名字。

   以下这样操作会抛出异常。

   必须借助group_concat()函数来进行操作才能使我们的需求圆满完成。

6.3、分组模式

   ONLY_FULL_GROUP_BY要求select中的字段是在与group by中使用的字段

   如果group by是主键或unique not null时可以在select中列出其他字段

6.4、聚合函数

   聚合函数可以在where执行后的所有语句中使用,比如having,select等。

   聚合函数一般是同分组进行配套使用,以下是常用的聚合函数。

函数名 作用
COUNT() 对组内成员某一字段求个数
MAX() 对组内成员某一字段求最大值
MIN() 对组内成员某一字段求最小值
AVG() 对组内成员某一字段求平均值
SUM() 对组内成员某一字段求和
注意:不使用分组,则默认为一组  

   以下示例将展示求每组的成绩总和

   以下示例将展示整个班级的平均成绩及总成绩(round()用于四舍五入操作)

   以下示例将展示打印出总科成绩最高分数

   以下示例将展示查看本班有多少男生,多少女生

7、having

   having也可用于过滤操作

7.1、区别差异

   执行优先级从高到低:where> group by > having

   where发生在分组group by之前,因而where中可以有任意字段,但是绝对不能使用聚合函数。

   having发生在分组group by之后,因而having中可以使用分组的字段,无法直接取到其他字段,可以使用聚合函数

7.2、示例演示

   以下示例将展示使用having过滤取出每组总分数大于400的小组

   以下示例将展示使用having过滤取出有处分的同学。(可以使用分组的字段,但不能使用其他字段)

8、ordery by

   ordery by用于对查询结果进行排序

   默认的排序是按照主键进行排序的

8.1  asc

   asc用于升序排列,以下示例将展示按照每位同学的年龄进行升序排列,如果年龄相同则依照总成绩进行升序排列。

8.2、desc

   desc用于降序排列,以下示例将展示按照每位同学的年龄进行降序排列。

9、limit

   limit用于控制显示的条数

9.1、示例演示

   按照总成绩进行降序排序,只打印1-5名。

   按照总成绩进行降序排序,只打印6-8名。

总结

到此这篇关于MySQL单表查询的文章就介绍到这了,更多相关MySQL单表查询内容请搜索我是攻城狮以前的文章或继续浏览下面的相关文章希望大家以后多多支持我是攻城狮!

本文来自网络,不代表我是攻城狮立场,转载请注明出处:https://www.54gcs.cn/sql/mysql/6055.html

helwo作者

上一篇
下一篇

为您推荐

发表评论

联系我们

联系我们

在线咨询: QQ交谈

邮箱: web@5vo.cn

工作时间:周一至周五,9:00-17:30,节假日休息
关注微信
微信扫一扫关注我们

微信扫一扫关注我们

手机访问
手机扫一扫打开网站

手机扫一扫打开网站

返回顶部
跳至工具栏