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

相关推荐
2501_901200531 分钟前
mysql如何设置InnoDB引擎参数_优化innodb_buffer_pool
jvm·数据库·python
m0_495496411 小时前
mysql处理复杂SQL性能_InnoDB优化器与MyISAM差异
jvm·数据库·python
forEverPlume2 小时前
PHP怎么使用Eloquent Attribute Composition属性组合_Laravel通过组合构建复杂属性【方法】
jvm·数据库·python
2301_809204702 小时前
mysql在docker容器中如何部署_利用docker-compose快速启动
jvm·数据库·python
虹科网络安全2 小时前
艾体宝产品|深度解读 Redis 8.4 新增功能:原子化 Slot 迁移(上)
数据库·redis·bootstrap
阿坤带你走近大数据3 小时前
怎么查看当前oracle库下的表空间temp大小或者默认大小
数据库·oracle
yoyo_zzm3 小时前
Laravel8.x新特性全解析
数据库·nginx
码界奇点3 小时前
基于Python的新浪微博数据爬虫系统设计与实现
数据库·爬虫·python·毕业设计·新浪微博·源代码管理
我科绝伦(Huanhuan Zhou)4 小时前
探索技术世界:我的GitHub数据库工具宝库
数据库·github
猫的玖月5 小时前
(一)MY SQL概述
数据库·sql