我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MySQL高级查询语法是什么

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

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MySQL高级查询语法是什么

这篇文章将为大家详细讲解有关MySQL高级查询语法是什么,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

一、排序

排序查询语法:

select * from 表名 order by 列1 asc/desc [,列2 asc/desc,...]

语法说明:

先按照列1进行排序,如果列1的值相同时,则按照列2排序asc:升序排序(从小到大)desc:降序排序(从大到小)默认是升序排序(asc)

查询未删除男生信息,按学号降序:

select * from students where is_del = 0 and sex = '男' order by id desc;

MySQL高级查询语法是什么

显示所有学生信息,先按年龄从大到小排序,年龄相同时按身高由高到低排序:

select * from students order by age desc,height desc;

MySQL高级查询语法是什么

二、分页查询

在网上购物时,浏览商品列表的时候,由于数据特别多,一页显示不完,一页一页的进行显示,这就是分页查询

select * from 表名 limit start,count

说明:

limit 是分页查询关键字start 表示开始行索引,默认是0count 表示查询条数

查询前三行男生的信息:

select * from students where sex='男' limit 0,3;

可以简写为

select * from students where sex='男' limit 3;

MySQL高级查询语法是什么

MySQL高级查询语法是什么

每页显示m条数据,求第n页显示的数据(关键是求每页的开始行索引)

select * from students limit (n-1)*m,m;

三、聚合函数

聚合函数又叫组函数,通常是对表中的数据进行统计和计算,一般结合分组(group by)来使用,用于统计和计算分组数据

常用的聚合函数:

count(col):表示求指定列的总行数max(col):表示求指定列的最大值min(col):表示求指定列的最小值sum(col):表示求指定列的和avg(col):表示指定列的平均值

求总行数:

返回非null数据的总行数select count(height) from students;返回总行数,包含null值记录select count(*) from students;

MySQL高级查询语法是什么

MySQL高级查询语法是什么

求最大值:

查询男生编号的最大值select max(id) from students where sex='男';

MySQL高级查询语法是什么

求最小值:

查询未删除的学生最小编号select min(id) from students where is_del=0;

MySQL高级查询语法是什么

求和:

查询男生的总身高select sum(height) from students where sex='男';查询男生的平均身高select sum(height) / count(*) from students where sex='男';

MySQL高级查询语法是什么

求平均值:

求男生的平均身高,聚合函数不统计null值select avg(height) from students where sex='男';求男生的平均身高,包含身高为null的值select avg(ifnull(height,0)) from students where sex='男';

说明:

ifnull函数:表示判断指定字段的值是否为null,如果为空则使用自己提供的值

MySQL高级查询语法是什么

聚合函数特点:

聚合函数默认忽略字段为null的记录,要想列值为null的记录也参与计算,必须使用ifnull函数对null值做替换

四、分组查询

分组查询就是将查询结果按照指定字段进行分组,字段中数据相等的分为一组

分组查询基本的语法格式:

group by 列名 [having 条件表达式] [with rollup]

说明:

列名:是指按照指定字段的值进行分组having 条件表达式:用来过滤分组后的数据with rollup:在所有记录的最后加上一条记录,显示select查询时聚合函数的统计和计算结果

group by 的使用:

group by可用于单个字段分组,也可用于多个字段分组

根据sex字段来分组select gender from students group by sex;根据name和sex字段来分组select name,sex from students group by name,sex;

MySQL高级查询语法是什么

group by + group_concat()的使用:

group_concat(字段名):统计每个分组指定字段的信息集合,每个信息之间用逗号分割

根据sex字段进行分组,查询sex字段和分组的name字段信息select sex,group_concat(name) from students group by sex;

MySQL高级查询语法是什么

group by + 聚合函数的使用:

统计不同性别的人的平均年龄select sex,avg(age) from students group by sex;统计不同性别的人的个数select sex,count(*) from students group by sex;

MySQL高级查询语法是什么

group by + having的使用:

having作用和where类似都是过滤数据的,但having是过滤分组数据的,只能用于group by

根据sex字段进行分组,统计分组条数大于2的select sex,count(*) from students group by sex having count(*)>2;

MySQL高级查询语法是什么

group by + with rollup的使用:

with rollup的作用是:在最后记录后面新增一行,显示select查询时聚合函数的统计和计算结果

根据sex字段进行分组,汇总总人数select sex,count(*) from students group by sex with rollup;根据sex字段进行分组,汇总所有人年龄select sex,group_concat(age) from students group by sex with rollup;

MySQL高级查询语法是什么

MySQL高级查询语法是什么

小结:

group by 根据指定的一个或者多个字段对数据进行分组group_concat(字段名)函数是统计每个分组指定字段的信息集合聚合函数在和group by 结合使用时,聚合函数统计和计算的是每个分组的数据having 是对分组数据进行条件过滤with rollup 在最后记录后面新增一行,显示select查询时聚合函数的统计和计算结果

五、连接查询

连接查询可以实现多个表的查询,当查询的字段数据来自不同的表就可以使用连接查询来完成

连接查询分为:

内连接查询左连接查询右连接查询自连接查询

1. 内连接查询

查询两个表中符合条件的共有记录(取交集)

内连接查询语法格式:

select 字段 from 表1 inner join 表2 on 表1.字段1 = 表2.字段2

说明:

inner join 就是内连接查询关键字on 就是连接查询条件

使用内连接查询学生表与班级表:

select * from students s inner join classes c on s.c_id = c.id;

原本两个表的内容:

MySQL高级查询语法是什么

MySQL高级查询语法是什么

使用内连接:

MySQL高级查询语法是什么

MySQL高级查询语法是什么

2. 左连接查询

以左表为主根据条件查询右表数据,如果根据条件查询右表数据不存在则使用null值填充

左连接查询语法格式:

select 字段 from 表1 left join 表2 on 表1.字段1 = 表2.字段2

说明:

left join 就是左连接查询关键字on 就是连接查询条件表1 是左表表2 是右表

使用左连接查询学生表与班级表:

select * from students s left join classes c on s.c_id = c.id;

MySQL高级查询语法是什么

3. 右连接查询

以右表为主根据条件查询左表数据,如果根据条件查询左表数据不存在则使用null值填充

右连接查询语法格式:

select 字段 from 表1 right join 表2 on 表1.字段1 = 表2.字段2;

说明:

right join 就是右连接查询关键字on 就是连接查询条件表1 是左表表2 是右表

使用右连接查询学生表与班级表:

select * from students s right join classes c on s.c_id = c.id;

MySQL高级查询语法是什么

MySQL高级查询语法是什么

4. 自连接查询

左表和右表是同一个表,根据连接查询条件查询两个表中的数据

MySQL高级查询语法是什么

创建areas表:

create table areas(id varchar(20) not null primary key,title varchar(30) not null,pid varchar(20));

执行sql文件给areas表导入数据:

source areas.sql;

sql文件内容:

insert into areas values('11000', '北京市', null);insert into areas values('11001', '北京市', '11000');insert into areas values('11002', '东城区', '11001');insert into areas values('11003', '西城区', '11001');insert into areas values('11004', '朝阳区', '11001');insert into areas values('11005', '丰台区', '11001');insert into areas values('11006', '海淀区', '11001');insert into areas values('12000', '河北省', null);insert into areas values('12001', '石家庄市', '12000');insert into areas values('12002', '长安区', '12001');insert into areas values('12003', '桥东区', '12001');insert into areas values('12004', '桥西区', '12001');insert into areas values('12005', '新华区', '12001');

说明:

source 表示执行的sql文件

自连接查询的用法:

select c.id, c.title, c.pid, p.title from areas c inner join areas p on c.pid = p.id;

说明:

自连接查询必须对表起别名

MySQL高级查询语法是什么

六、子查询

在一个select语句中,嵌入了另外一个select语句,那么被嵌入的select语句称之为子查询语句,外部的那个select语句则称为主查询

主查询和子查询的关系:

子查询是嵌入到主查询中子查询是辅助主查询的,要么充当条件,要么充当数据源子查询是可以独立存在的语句,是一条完整的select语句

查询大于平均年龄的学生:

select * from students where age > (select avg(age) from students);

MySQL高级查询语法是什么

查询学生在班的所有班级名字:

select name from classes where id in (select c_id from students where c_id is not null);

MySQL高级查询语法是什么

查找年龄最大,身高最高的学生:

select * from students where age=(select max(age) from students) and height=(select max(height) from students);可以简写为:select * from students where (age,height) = (select max(age), max(height) from students);

MySQL高级查询语法是什么

关于“MySQL高级查询语法是什么”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

免责声明:

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

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

MySQL高级查询语法是什么

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

MySQL高级查询语法是什么

这篇文章将为大家详细讲解有关MySQL高级查询语法是什么,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、排序排序查询语法:select * from 表名 order by 列1 asc/desc [,
2023-06-29

Lucene查询语法是什么

Lucene查询语法是一种用于构建搜索查询的语法,它是由Apache Lucene搜索引擎库提供的。以下是Lucene查询语法的一些重要组成部分:关键字查询:可以使用关键字进行简单的全文搜索,例如 "lucene"。字段查询:可以指定要搜
2023-10-21

prometheus的查询语法是什么

Prometheus 查询语言是一个用于从 Prometheus 时间序列数据库中提取、聚合和处理数据的强大工具。其基本语法包括标识符、操作符、函数、数据类型和聚合器等。以下是一些基本的 Prometheus 查询语法示例:查询所有指标名
prometheus的查询语法是什么
2024-03-14

mysql递归查询所有子级的方法是什么

在MySQL中,可以使用递归查询(Recursive Query)来查询所有子级。MySQL并不直接支持递归查询,但可以通过使用`WITH RECURSIVE`语句以及递归联结来实现递归查询。以下是一个示例查询所有子级的MySQL递归查询的
2023-09-11

mysql查询的基本语句是什么

mysql 的基本查询语句是 select,它用于从数据库表中检索数据。select 语法包括:select [distinct] 列名1, 列名2, ...from 表名where 条件having 分组条件[limit 限制行数]。My
mysql查询的基本语句是什么
2024-04-22

mysql单表千万级数据查询的方法是什么

在处理千万级数据的单表查询时,可以采取以下方法来提高查询效率:使用合适的索引:在主键字段和经常用于查询的字段上创建索引,可以加快查询速度。但是要注意索引也会占用存储空间,并且会增加更新和插入操作的时间。避免全表扫描:尽量避免使用没有索引的字
mysql单表千万级数据查询的方法是什么
2024-03-02

mysql的join查询和多次查询方法是什么

这篇文章主要讲解了“mysql的join查询和多次查询方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mysql的join查询和多次查询方法是什么”吧!join查询和多次查询比较My
2023-03-09

Sphinx搜索中的查询语法与高级功能探索(Sphinx支持哪些查询语法和高级功能?)

Sphinx搜索支持多种查询语法,包括布尔运算、模糊匹配、通配符、分组、Proximity搜索和范围查询。它还提供高级功能,例如索引权重、过滤、分组、排序、分页、高亮显示、自定义函数和地理空间搜索。Sphinx还集成了自然语言处理、机器学习、实时搜索、多索引搜索和分布式搜索等功能。通过利用这些语法和功能,开发者可以创建复杂且有效的搜索查询,从而提升搜索体验。
Sphinx搜索中的查询语法与高级功能探索(Sphinx支持哪些查询语法和高级功能?)
2024-04-02

MySQL查询语句执行流程是什么

这篇“MySQL查询语句执行流程是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“MySQL查询语句执行流程是什么”文章吧
2023-07-05

mysql中查询数据的语句是什么

mysql 中查询数据的语句是 select 语句,它用于从表中检索指定的行和列数据。语法为:select column_list from table_name [where condition] [group by group_by_c
mysql中查询数据的语句是什么
2024-05-01

mysql查询语法怎么写

mysql查询语法用于从数据库中检索数据,包括:select关键字、列名、from关键字、where子句和order by子句。where子句使用运算符过滤结果,而order by子句使用关键字asc或desc对结果按升序或降序排序。MyS
mysql查询语法怎么写
2024-05-22

SQL Server 的T-SQL高级查询指的是什么

小编今天带大家了解SQL Server 的T-SQL高级查询指的是什么,文中知识点介绍的非常详细。觉得有帮助的朋友可以跟着小编一起浏览文章的内容,希望能够帮助更多想解决这个问题的朋友找到问题的答案,下面跟着小编一起深入学习“SQL Serv
2023-06-26

二级域名查询的方法是什么

要查询一个二级域名,可以按照以下步骤进行:1. 打开一个域名查询网站,如whois.com或dnswatch.info。2. 在查询框中输入要查询的二级域名,例如example.com。3. 点击“查询”按钮。4. 系统会显示与该域名相关的
2023-06-12

mysql去重查询的方法是什么

在 MySQL 中,可以使用 DISTINCT 关键字来进行去重查询,该关键字用于返回唯一不同的值。以下是一个简单的示例:SELECT DISTINCT column1, column2 FROM table_name;上面的示例将返回
mysql去重查询的方法是什么
2024-04-09

编程热搜

目录