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子句的灵活使用是进行高效数据检索的关键。通过合理的列选择、表达式使用和表引用,可以构建出既高效又易于维护的查询语句。在实际开发中,建议根据具体需求选择合适的查询方式,并注意查询性能的优化。

相关推荐
茉莉玫瑰花茶2 小时前
综合案例 - AI 智能租房助手 [ 5 ]
服务器·数据库·人工智能·python·ai
ywl4708120872 小时前
jwt生产token,简单版helloworld
java·数据库·spring
器灵科技2 小时前
AI视频工具实测:Seedance/可灵/HappyHorse谁最能打?
java·运维·数据库·人工智能·github
摇滚侠2 小时前
MyBatis 入门到项目实战 特殊 SQL 的执行 34-37
java·sql·mybatis
huangdong_2 小时前
京东商品图片视频批量下载与m3u8视频合并技术完整实现方案
大数据·前端·数据库
倒流时光三十年2 小时前
PostgreSQL CASE 条件表达式详解
数据库·postgresql
字节跳动数据平台3 小时前
营销视频进入工业化时代,火山引擎多模态数据湖如何助力多米实现内容生产提效 100+ 倍
数据库
layflat_coder3 小时前
NL2SQL 正确率怎么提升:ChatBI 的 `<error-msg>` 错误反馈闭环
sql
健康平安的活着3 小时前
mysql中数据库脚本太大,通过脚本命令修改db名称
数据库·mysql
倒流时光三十年3 小时前
PostgreSQL COALESCE 条件表达式函数详解
数据库·postgresql