MySQL查询语句

在查询之前,我们也先准备好一些数据

-- 创建 db2 数据库 CREATE DATABASE db2;-- 使用 db2 数据库 USE db2;-- 数据 student 数据表 CREATE

TABLE student (

id INT, -- 编号

NAME VARCHAR(20), -- 姓名

age INT, -- 年龄

sex VARCHAR(5), -- 性别

address VARCHAR(100), -- 地址

math INT, -- 数学

english INT -- 英语);

-- 添加表记录

INSERT INTO student(id,NAME,age,sex,address,math,english) VALUES (1,'马云',55,'','杭州',66,78),(2,'马化腾',45,'','深',98,87),(3,'马景涛',55,'','香港',56,77),(4,'柳岩',20,'女','湖南',76,65),(5,'柳青',20,'','湖南',86,NULL),(6,'刘德华',57,'','香港',99,99),(7,'马德',22,'','香港',99,99),(8,'德玛西亚',18,'','南京',56,65);

数据如下

MySQL查询语句_第1张图片

DQL 排序查询

MySQL查询语句_第2张图片

下图为最后一条 sql 语句排序的结果集

MySQL查询语句_第3张图片

DQL 聚合函数

聚合函数指在查询数据时可以将一列数据进行纵向的计算。掌握下面几个聚合函数。

MySQL查询语句_第4张图片

-- 聚合函数查询的语法 SELECT 聚合函数(列名) FROM 表名

COUNT 函数

-- 注意:如果类中有 NULL 值,不算个数

-- student 表中 math 列有多少条记录,结果为 8

SELECT COUNT(math) FROM student;

-- student 表中 english 列有多少条记录,结果为 7,因为有一个 NULL

SELECT COUNT(english) FROM student;

-- 查询所有列个数【比较常用】

SELECT COUNT(*) FROM student;

执行结果为

MySQL查询语句_第5张图片

MIN 函数

--查询 math 的最小值

SELECT MIN(math) FROM student;

MAX 函数

-- 查询 math 的最大值

SELECT MAX(math) FROM student;

MySQL查询语句_第6张图片

SUM 函数

-- 查询 math 的和

SELECT SUM(math) FROM student;

AVG 函数

-- 查询 math 的平均值

SELECT AVG(math) FROM student;

MySQL查询语句_第7张图片

DQL 分组查询

按照特定条件把数据进行分组,把每一组当做一个整体,分别对某一组数据进行计算。

-- 分组查询语法,字段列表只能是分组列、或者聚合函数 SELECT 字段列表 FROM 表名 where 分组前条件

GROUP BY 分组列名 HAVING 分组后条件

对所有数据分组查询

-- 按姓别进行分别,查询男、女的 math 的平均值

SELECT sex,AVG(math) FROM student GROUP BY sex;

-- 按性别进行分组,查询男、女同学的 math 平均分,和人数 SELECT sex, AVG(math), COUNT(id) FROM

student GROUP BY sex;

MySQL查询语句_第8张图片

分组前筛选

-- 分组前进行筛选使用 where 子句-- >70 分的人按照性别进行分组,查询男、女同学的 math 平均分和人数

SELECT sex, AVG(math),COUNT(id) FROM student WHERE math>70 GROUP BY sex;

MySQL查询语句_第9张图片

分组后筛选

-- 分组后再进行筛选,使用 having 子句-- >70 分的人按照性别进行分组,查询男、女同学的 math 平均分

和人数,再筛选人数>2 的数据

SELECT sex, AVG(math),COUNT(id) FROM student WHERE math>70 GROUP BY sex HAVING COUNT(id)>2;

-- 可以使用 AS 语句给聚合函数取别名,改进上面的 sql 语句

SELECT sex, AVG(math) AS 平均分,COUNT(id) AS 个数 FROM student WHERE math>70 GROUP BY sex HAVING

个数>2;

DQL 分页查询

分页查询指当要查询的数据量比较多的时候,采用一次查询固定条记录的方式。

-- 开始索引=(当前页码-1)*个数

select 字段列表 from 表名 limit 开始索引,个数

-- 查询 0 索引开始的 3 条记录

SELECT * FROM student LIMIT 0,3; -- 1

MySQL查询语句_第10张图片

-- 查询 3 索引开始的 3 条记录

SELECT * FROM student LIMIT 3,3; -- 2

MySQL查询语句_第11张图片

-- 查询 6 索引开始的 3 条记录

SELECT * FROM student LIMIT 6,3; -- 3

你可能感兴趣的:(MySQL查询语句)