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

相关推荐
Drifter_yh2 小时前
【黑马点评】Redisson 分布式锁核心原理剖析
java·数据库·redis·分布式·spring·缓存
鸽鸽程序猿2 小时前
【Redis】zset 类型介绍
数据库·redis·缓存
z玉无心2 小时前
Redis
数据库·redis·oracle
予枫的编程笔记2 小时前
【Redis核心原理篇2】Redis 单线程模型:为什么单线程还能这么快?
数据库·redis·缓存
fengxin_rou2 小时前
一文吃透 Redis 压缩列表、listpack 及哈希表扩容与并发查询
数据库·redis·散列表
一只鹿鹿鹿2 小时前
智慧水利一体化建设方案
大数据·运维·开发语言·数据库·物联网
_codemonster3 小时前
数据库字符集编码问题
android·数据库·oracle
xuzhiqiang07245 小时前
MySQL——数据库的操作
数据库·mysql·oracle
德迅云安全-小潘5 小时前
德迅零域(微隔离):破解云时代横向渗透困局的“手术刀”
网络·数据库·安全
敲代码的哈吉蜂5 小时前
高可用集群Keepalived
运维·服务器·网络·数据库