MySQL表的数据检索:从基础到精通

一、基本SELECT查询语句格式

1.1 SELECT语句的基本结构

SELECT语句是MySQL中最核心的查询命令,用于从一个或多个表中检索数据。其基本语法格式如下:

bash 复制代码
sql
SELECT 
    [ALL | DISTINCT | DISTINCTROW]
    select_expr [, select_expr ...]
FROM 
    table_references
[WHERE where_condition]
[GROUP BY {col_name | expr | position}]
[HAVING where_condition]
[ORDER BY {col_name | expr | position} [ASC | DESC]]
[LIMIT {[offset,] row_count | row_count OFFSET offset}];

1.2 最简查询示例

sql

bash 复制代码
-- 查询表中所有数据的所有列
SELECT * FROM employees;

-- 查询表中特定列
SELECT id, name, department FROM employees;

-- 查询并给列起别名
SELECT 
    id AS '员工编号',
    name AS '员工姓名',
    salary AS '基本工资'
FROM employees;

1.3 查询执行顺序说明

FROM:指定数据来源的表

WHERE:对记录进行筛选

GROUP BY:对结果进行分组

HAVING:对分组结果进行筛选

SELECT:选择显示的列

ORDER BY:对结果进行排序

LIMIT:限制返回的记录数

二、单表查询:SELECT子句和FROM子句详解

2.1 SELECT子句的丰富功能

2.1.1 查询所有列

sql

bash 复制代码
-- 使用星号(*)查询所有列
SELECT * FROM products;

2.1.2 查询特定列

bash 复制代码
sql
-- 选择特定列,提高查询效率
SELECT 
    product_id,
    product_name,
    price,
    category
FROM products;

2.1.3 使用表达式和函数

bash 复制代码
sql
-- 使用算术表达式
SELECT 
    product_name,
    price,
    price * 0.9 AS '折扣价',
    stock_quantity
FROM products;

-- 使用字符串函数
SELECT 
    CONCAT(last_name, ' ', first_name) AS '员工全名',
    UPPER(department) AS '部门',
    LENGTH(email) AS '邮箱长度'
FROM employees;

-- 使用日期函数
SELECT 
    order_id,
    customer_name,
    order_date,
    DATE_ADD(order_date, INTERVAL 7 DAY) AS '预计发货日',
    YEAR(order_date) AS '订单年份'
FROM orders;

2.1.4 使用DISTINCT去重

bash 复制代码
sql
-- 获取唯一的部门列表
SELECT DISTINCT department FROM employees;

-- 多个列的组合去重
SELECT DISTINCT department, job_title FROM employees;

2.1.5 使用CASE表达式

bash 复制代码
sql
SELECT 
    student_id,
    student_name,
    score,
    CASE
        WHEN score >= 90 THEN '优秀'
        WHEN score >= 80 THEN '良好'
        WHEN score >= 60 THEN '及格'
        ELSE '不及格'
    END AS '成绩等级'
FROM exam_results;

2.2 FROM子句的灵活运用

2.2.1 基本表查询

sql

bash 复制代码
-- 查询单个表
SELECT * FROM customers;

-- 为表指定别名(提高可读性)
SELECT 
    c.customer_id,
    c.customer_name,
    c.join_date
FROM customers AS c;

2.2.2 虚拟表(子查询作为表)

bash 复制代码
sql
-- 子查询作为数据源
SELECT 
    sub.dept_name,
    sub.avg_salary
FROM (
    SELECT 
        department AS dept_name,
        AVG(salary) AS avg_salary
    FROM employees
    GROUP BY department
    HAVING AVG(salary) > 5000
) AS sub
ORDER BY sub.avg_salary DESC;

2.2.3 使用DUAL虚拟表

bash 复制代码
sql
-- DUAL是MySQL中的虚拟表,用于计算表达式
SELECT 
    'MySQL数据检索' AS title,
    NOW() AS current_time,
    10 * 20 AS calculation,
    VERSION() AS mysql_version
FROM DUAL;

2.3 实用查询示例集合

bash 复制代码
示例1:基础数据检索
sql
-- 查询员工基本信息
SELECT 
    emp_id AS '编号',
    CONCAT(first_name, ' ', last_name) AS '姓名',
    department AS '部门',
    FORMAT(salary, 2) AS '月薪',
    DATE_FORMAT(hire_date, '%Y-%m-%d') AS '入职日期'
FROM employees
WHERE department = '技术部'
ORDER BY salary DESC;
示例2:数据统计分析
sql
-- 统计各部门人数和平均薪资
SELECT 
    department AS '部门名称',
    COUNT(*) AS '员工人数',
    FORMAT(AVG(salary), 2) AS '平均薪资',
    FORMAT(MAX(salary), 2) AS '最高薪资',
    FORMAT(MIN(salary), 2) AS '最低薪资',
    SUM(salary) AS '薪资总额'
FROM employees
GROUP BY department
HAVING COUNT(*) > 5
ORDER BY AVG(salary) DESC;
示例3:数据筛选与格式化
sql
-- 高级数据筛选和格式化
SELECT 
    p.product_id AS '产品ID',
    p.product_name AS '产品名称',
    p.category AS '产品类别',
    CASE 
        WHEN p.price > 1000 THEN '高端'
        WHEN p.price > 500 THEN '中端'
        ELSE '入门'
    END AS '价格分类',
    p.stock_quantity AS '库存',
    IF(p.stock_quantity > 100, '充足', '需补货') AS '库存状态'
FROM products AS p
WHERE p.price BETWEEN 100 AND 5000
  AND p.stock_quantity > 0
ORDER BY p.price DESC, p.stock_quantity ASC;

2.4 性能优化建议

**避免使用SELECT ***:明确指定需要的列

合理使用别名:提高查询可读性

WHERE子句优化:尽量使用索引列进行筛选

LIMIT分页:大数据量时使用分页查询

减少函数使用:WHERE子句中避免对列使用函数

总结

MySQL的SELECT查询是数据库操作的基础,掌握SELECT和FROM子句的灵活使用是进行高效数据检索的关键。通过合理的列选择、表达式使用和表引用,可以构建出既高效又易于维护的查询语句。在实际开发中,建议根据具体需求选择合适的查询方式,并注意查询性能的优化。

相关推荐
冉冰学姐几秒前
基于ssm的技能比赛报名管理系统29817vn0(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
java·数据库·spring·ssm 框架应用
小小码农Come on2 小时前
Qt Creator + MSVC 2022 64bit 配置 Dump 文件生成与分析流程
数据库·qt
qiuyuyiyang2 小时前
【MySQL】环境变量配置
数据库·mysql·adb
神仙别闹4 小时前
基于NodeJS+Vue+MySQL实现一个在线编程笔试平台
前端·vue.js·mysql
jgyzl4 小时前
2026.3.11MyBatis-Plus基本使用与思考
java·数据库·mybatis
RDCJM4 小时前
【MySQL】在MySQL中STR_TO_DATE()以及其他用于日期和时间的转换
android·数据库·mysql
vanvivo4 小时前
redis 使用
数据库·redis·缓存
加成BUFF5 小时前
解决MySQL/MariaDB忘记root密码:完整重置教程(XAMPP/Windows版)
数据库·mysql·xampp
杰克尼5 小时前
苍穹外卖--day10
java·数据库·spring boot·mybatis·notepad++
dreamread5 小时前
完美解决phpstudy安装后mysql无法启动
数据库·mysql