MySQL排序分组限制:零基础速成语法(零基础入门版)

一、ORDER BY(排序):让数据排好队

bash 复制代码
最简单格式
sql
SELECT * FROM 表名 
ORDER BY 列名 [升序或降序];

1. 升序(从小到大)

bash 复制代码
sql
-- 按成绩从小到大排
SELECT * FROM students ORDER BY score;
-- 或者明确写ASC(可以省略)
SELECT * FROM students ORDER BY score ASC;

2. 降序(从大到小)

bash 复制代码
sql
-- 按成绩从大到小排
SELECT * FROM students ORDER BY score DESC;

3. 多个排序条件

bash 复制代码
sql
-- 先按班级排,再按成绩降序排
SELECT * FROM students 
ORDER BY class, score DESC;
示例表
sql
-- 创建简单示例表
CREATE TABLE students (
    id INT,
    name VARCHAR(20),
    class VARCHAR(10),
    score INT
);

-- 插入数据
INSERT INTO students VALUES
(1, '张三', '一班', 85),
(2, '李四', '二班', 92),
(3, '王五', '一班', 78),
(4, '赵六', '二班', 65),
(5, '孙七', '一班', 88);
练习1:排序查询
sql
-- 1. 按分数从高到低排
SELECT * FROM students ORDER BY score DESC;

-- 2. 先按班级排,再按分数排
SELECT * FROM students ORDER BY class, score DESC;
结果对比:

text
按分数排序(降序):
id  name  class  score
2   李四   二班    92
5   孙七   一班    88
1   张三   一班    85
3   王五   一班    78
4   赵六   二班    65

二、GROUP BY(分组):把相同的数据放一起

bash 复制代码
最简单格式
sql
SELECT 列名, 统计函数(列名)
FROM 表名
GROUP BY 列名;

常用统计函数

函数 意思 例子

COUNT() 数一数有多少个 COUNT( )

SUM(列名) 加起来是多少 SUM(score)

AVG(列名) 平均是多少 AVG(score)

MAX(列名) 最大的是多少 MAX(score)

MIN(列名) 最小的是多少 MIN(score)

bash 复制代码
例子1:统计每个班的人数
sql
SELECT 
    class AS '班级',
    COUNT(*) AS '人数'
FROM students
GROUP BY class;
结果:

text
班级  人数
一班    3
二班    2
例子2:统计每个班的平均分
sql
SELECT 
    class AS '班级',
    AVG(score) AS '平均分'
FROM students
GROUP BY class;
结果:

text
班级  平均分
一班    83.6667
二班    78.5000
练习2:分组查询
sql
-- 1. 每个班的最高分
SELECT class, MAX(score) FROM students GROUP BY class;

-- 2. 每个班的总分
SELECT class, SUM(score) FROM students GROUP BY class;

三、HAVING(分组后的筛选)

bash 复制代码
最简单格式
sql
SELECT 列名, 统计函数(列名)
FROM 表名
GROUP BY 列名
HAVING 统计函数(列名) 条件;
bash 复制代码
例子:找平均分大于80的班级
sql
SELECT 
    class,
    AVG(score) AS avg_score
FROM students
GROUP BY class
HAVING AVG(score) > 80;
练习3:HAVING使用
sql
-- 1. 找人数的班级
SELECT class, COUNT(*) FROM students 
GROUP BY class 
HAVING COUNT(*) >= 3;

-- 2. 找最高分大于85的班级
SELECT class, MAX(score) FROM students 
GROUP BY class 
HAVING MAX(score) > 85;

四、LIMIT(限制显示多少条)

bash 复制代码
最简单格式
sql
-- 显示前N条
SELECT * FROM 表名 LIMIT 数量;

-- 显示第M条开始的N条(分页用)
SELECT * FROM 表名 LIMIT M, N;
例子1:显示前3名
sql
-- 显示分数最高的3个人
SELECT * FROM students 
ORDER BY score DESC 
LIMIT 3;
例子2:分页显示(每页2条)
sql
-- 第1页
SELECT * FROM students LIMIT 0, 2;

-- 第2页
SELECT * FROM students LIMIT 2, 2;

-- 第3页
SELECT * FROM students LIMIT 4, 2;

五、完整例子(一步步来)

bash 复制代码
步骤1:创建销售表
sql
CREATE TABLE sales (
    id INT,
    product VARCHAR(20),
    salesperson VARCHAR(20),
    amount DECIMAL(10,2),
    sale_date DATE
);

INSERT INTO sales VALUES
(1, '手机', '张三', 2999, '2023-10-01'),
(2, '电脑', '李四', 6999, '2023-10-01'),
(3, '手机', '张三', 2999, '2023-10-02'),
(4, '平板', '王五', 3999, '2023-10-02'),
(5, '电脑', '李四', 6999, '2023-10-03'),
(6, '手机', '王五', 2999, '2023-10-03');
步骤2:各种查询练习
练习1:按销售员分组,看每个人卖了多少钱

sql
SELECT 
    salesperson AS '销售员',
    SUM(amount) AS '总销售额'
FROM sales
GROUP BY salesperson
ORDER BY SUM(amount) DESC;
练习2:找销售额大于5000的销售员

sql
SELECT 
    salesperson,
    SUM(amount) AS total
FROM sales
GROUP BY salesperson
HAVING SUM(amount) > 5000;
练习3:按产品分组,看每个产品卖了多少

sql
SELECT 
    product AS '产品',
    COUNT(*) AS '销售次数',
    SUM(amount) AS '总金额'
FROM sales
GROUP BY product;
练习4:显示销售额前2名的销售员

sql
SELECT 
    salesperson,
    SUM(amount) AS total
FROM sales
GROUP BY salesperson
ORDER BY total DESC
LIMIT 2;

📌 终极简版(就记这些)

排序:ORDER BY 列名 ASC/DESC

分组:GROUP BY 列名 + COUNT/SUM/AVG

分组筛选:GROUP BY后面加HAVING

限制条数:最后加LIMIT 数字

格式:

bash 复制代码
sql
SELECT 列 
FROM 表 
WHERE 条件 
GROUP BY 列 
HAVING 条件 
ORDER BY 列 
LIMIT 数字;

记住这个顺序,MySQL查询就掌握了! 🎯

相关推荐
character08258 小时前
Django全栈开发入门:构建一个博客系统
jvm·数据库·python
NineData8 小时前
NineData 新增支持 MySQL 到 openGauss PostgreSQL 兼容版数据复制链路
数据库·mysql·程序员
晨曦_子画8 小时前
C# sql语句含有 like %name%如何提高查询效率
数据库·sql·c#
云贝教育-郑老师8 小时前
【5分钟学会部署OpenTenBase V5.0 for CentOS 7.8】
数据库·oracle
阿贵---8 小时前
定时任务专家:Python Schedule库使用指南
jvm·数据库·python
TsukasaNZ8 小时前
如何为开源Python项目做贡献?
jvm·数据库·python
尽兴-8 小时前
构建坚如磐石的 Redis 服务:数据安全性与高可用架构全解析
数据库·redis·架构·主从·aof·哨兵·rdb
老刘学达梦8 小时前
达梦数据库表统计信息收集时间分析
数据库
范纹杉想快点毕业8 小时前
C语言综合项目实战练手:基于C语言的简单数据库系统实现
服务器·c语言·数据库
2401_831920749 小时前
Python生成器(Generator)与Yield关键字:惰性求值之美
jvm·数据库·python