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

相关推荐
難釋懷2 小时前
Redis消息队列-基于Stream的消息队列
数据库·redis·缓存
GDAL2 小时前
SQLite 与 MySQL 性能深度对比:场景决定最优解
数据库·mysql·sqlite
troublea3 小时前
Laravel 8.x新特性全解析
数据库·mysql·缓存
焦糖玛奇朵婷3 小时前
做盲盒小程序,如何少走弯路?
数据库·程序人生·小程序·开源软件·软件需求
mi20063 小时前
Linux下安装postgresql记录
数据库·postgresql
清云随笔3 小时前
MySQL 的常见操作(基础)
数据库·mysql
汇智信科3 小时前
汇智信科网络考试系统:以技术赋能,重构在线测评新范式
linux·数据库·mysql·oracle·sqlserver·java技术
BullSmall3 小时前
从2026年春晚 详细分析未来IT行业的发展
linux·运维·服务器·数据库
正在走向自律3 小时前
高并发场景下一卡通系统数据库架构设计与实践
数据库·分布式·一卡通系统