在mysql数据库操作中,SELECT语句是用于从数据表中提取数据的核心命令,几乎所有需要获取数据的场景都会用到它。无论是简单的单表全量查询,还是复杂的多表关联、条件筛选、结果排序等操作,都可以通过SELECT语句的不同组合来实现。

SELECT查询的基础语法
最基础的SELECT查询语法结构如下,用于从指定的数据表中获取所有列的数据:
-- 查询指定表的所有数据 SELECT * FROM 表名;
如果只需要查询表中的部分列,可以将*替换为具体的列名,多个列名之间用英文逗号分隔:
-- 查询用户表的id、用户名、邮箱三列数据 SELECT id, username, email FROM user;
常用的查询条件子句
WHERE子句:筛选符合条件的记录
WHERE子句用于指定查询的条件,只有满足条件的数据才会被返回。常见的条件运算符包括等于=、不等于!=、大于>、小于<、大于等于>=、小于等于<=,还有逻辑运算符AND、OR、NOT。
-- 查询年龄大于18且状态为正常的用户 SELECT id, username, age FROM user WHERE age > 18 AND status = 'normal'; -- 查询姓名为张三或者年龄小于16的用户 SELECT * FROM user WHERE username = '张三' OR age < 16;
ORDER BY子句:对查询结果排序
ORDER BY子句用于对查询结果按照指定列进行排序,默认是升序(ASC),如果需要降序可以加上DESC关键字。
-- 按照年龄升序查询用户数据 SELECT id, username, age FROM user ORDER BY age ASC; -- 按照注册时间降序查询用户数据 SELECT id, username, create_time FROM user ORDER BY create_time DESC;
LIMIT子句:限制返回结果的数量
LIMIT子句用于限制查询结果返回的记录数,常用于分页场景,语法为LIMIT 起始偏移量, 返回条数,起始偏移量从0开始计数。
-- 查询前10条用户数据,偏移量为0可以省略 SELECT * FROM user LIMIT 10; -- 查询第11到20条用户数据,偏移量10,返回10条 SELECT * FROM user LIMIT 10, 10;
聚合查询与分组查询
聚合函数
mysql提供了常用的聚合函数,用于对一组数据进行统计计算,常见的聚合函数包括COUNT(统计数量)、SUM(求和)、AVG(求平均值)、MAX(求最大值)、MIN(求最小值)。
-- 统计用户表的总记录数 SELECT COUNT(*) AS total_user FROM user; -- 统计成年用户的平均年龄 SELECT AVG(age) AS avg_age FROM user WHERE age >= 18; -- 查询用户的最大年龄和最小年龄 SELECT MAX(age) AS max_age, MIN(age) AS min_age FROM user;
GROUP BY子句:分组统计
GROUP BY子句用于按照指定列对数据进行分组,通常和聚合函数一起使用,实现分组统计的需求。如果需要筛选分组后的结果,要使用HAVING子句,而不是WHERE子句。
-- 按照用户状态分组,统计每个状态的用户数量 SELECT status, COUNT(*) AS status_count FROM user GROUP BY status; -- 按照状态分组,筛选出用户数量大于100的状态 SELECT status, COUNT(*) AS status_count FROM user GROUP BY status HAVING status_count > 100;
多表关联查询
当查询的数据涉及多张表时,可以使用关联查询,常见的关联方式有内连接INNER JOIN、左连接LEFT JOIN、右连接RIGHT JOIN。
-- 内连接查询用户表和订单表,获取有订单的用户及订单信息 SELECT u.id, u.username, o.order_no, o.order_amount FROM user u INNER JOIN order_table o ON u.id = o.user_id; -- 左连接查询所有用户及其订单信息,没有订单的用户订单字段为NULL SELECT u.id, u.username, o.order_no, o.order_amount FROM user u LEFT JOIN order_table o ON u.id = o.user_id;
查询结果的别名设置
在SELECT查询中,可以使用AS关键字给列或者表设置别名,让查询结果更易读,也可以简化长表名的书写。
-- 给列设置别名 SELECT id AS 用户ID, username AS 用户名, age AS 年龄 FROM user; -- 给表设置别名,简化关联查询的书写 SELECT u.id, u.username, o.order_no FROM user AS u LEFT JOIN order_table AS o ON u.id = o.user_id;