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查询就掌握了! 🎯

相关推荐
CDA数据分析师干货分享2 小时前
【干货】CDA一级知识点拆解1:《CDA一级商业数据分析》第1章 数据分析思维
数据库·人工智能·数据分析·cda证书·cda数据分析师
数据知道2 小时前
PostgreSQL 核心原理:如何从日志中定位死锁根源(死锁检测与预防)
数据库·postgresql
物联网软硬件开发-轨物科技2 小时前
【轨物方案】告别“盲维”时代:如何不动一根电线,帮老旧电站找回消失的 5% 收益?
服务器·网络·数据库
司沐_Simuoss3 小时前
Text to SQL系统的千层套路~
数据库·人工智能·sql·语言模型·系统架构
ptc学习者3 小时前
验证mysql RR隔离水平,并未完全实现防止幻读的实验
数据库
小天源3 小时前
银河麒麟 V10(x86_64)离线安装 MySQL 8.0
android·mysql·adb·麒麟v10
qq_12498707533 小时前
基于协同过滤算法的运动场馆服务平台设计与实现(源码+论文+部署+安装)
java·大数据·数据库·人工智能·spring boot·毕业设计·计算机毕业设计
数据知道4 小时前
PostgreSQL 核心原理:读已提交与可重复读的底层实现差异(事务隔离级别)
数据库·postgresql
crossaspeed4 小时前
MySQL的MVCC
数据库·mysql