当前位置: 首页 > news >正文

详细介绍:【MySQL】基本查询

详细介绍:【MySQL】基本查询

MySQL 基本查询详解

在数据库应用开发中,增删改查(CRUD)是最常见的操作。掌握 MySQL 的基本查询语法,不仅能提升数据管理效率,还能为后续的复杂查询打下基础。本文将结合示例,从 Create、Retrieve、Update、Delete 四个方面详细介绍 MySQL 的基本查询。


一、Create(创建数据)

1.1 单行数据 + 全列插入

INSERT INTO students VALUES (101, 10001, '孙悟空', '11111');

要求插入的值与表中列的数量和顺序完全一致。


1.2 多行数据 + 指定列插入

INSERT INTO students (id, sn, name) VALUES
(102, 20001, '曹孟德'),
(103, 20002, '孙仲谋');

指定列时,可以让自增列自动赋值。


1.3 插入否则更新(ON DUPLICATE KEY UPDATE)

当主键或唯一键冲突时,可以选择更新:

INSERT INTO students (id, sn, name) VALUES (100, 10010, '唐大师')
ON DUPLICATE KEY UPDATE sn = 10010, name = '唐大师';

1.4 替换(REPLACE)

若存在冲突记录,则先删除再插入:

REPLACE INTO students (sn, name) VALUES (20001, '曹阿瞒');

二、Retrieve(查询数据)

2.1 SELECT 查询列

全列查询
SELECT * FROM exam_result;
指定列查询
SELECT id, name, english FROM exam_result;
查询字段为表达式
SELECT id, name, chinese + math + english 总分 FROM exam_result;
去重查询
SELECT DISTINCT math FROM exam_result;

2.2 WHERE 条件过滤

英语不及格的同学
SELECT name, english FROM exam_result WHERE english <
60;
语文成绩在 [80, 90] 分之间
SELECT name, chinese FROM exam_result WHERE chinese BETWEEN 80 AND 90;
模糊匹配(姓孙)
SELECT name FROM exam_result WHERE name LIKE '孙%';
NULL 查询
SELECT name, qq FROM students WHERE qq IS NOT NULL;

2.3 ORDER BY 排序

按数学成绩升序
SELECT name, math FROM exam_result ORDER BY math;
按总分降序
SELECT name, chinese + math + english 总分 FROM exam_result ORDER BY 总分 DESC;

2.4 LIMIT 分页

每页 3 条记录,第 1 页:

SELECT id, name, math, english, chinese
FROM exam_result ORDER BY id LIMIT 3 OFFSET 0;

三、Update(更新数据)

3.1 更新单列

UPDATE exam_result SET math = 80 WHERE name = '孙悟空';

3.2 更新多列

UPDATE exam_result SET math = 60, chinese = 70 WHERE name = '曹孟德';

3.3 基于原值更新

UPDATE exam_result SET math = math + 30 ORDER BY chinese + math + english LIMIT 3;

3.4 更新全表

UPDATE exam_result SET chinese = chinese * 2;

四、Delete(删除数据)

4.1 删除指定行

DELETE FROM exam_result WHERE name = '孙悟空';

4.2 删除整表数据

DELETE FROM for_delete;

4.3 截断表(清空并重置自增)

TRUNCATE TABLE for_truncate;

五、插入查询结果

可将查询结果插入新表:

INSERT INTO no_duplicate_table
SELECT DISTINCT * FROM duplicate_table;

六、聚合函数

  • 统计人数:
SELECT COUNT(*) FROM students;
  • 平均分:
SELECT AVG(chinese + math + english) 平均总分 FROM exam_result;
  • 最高/最低分:
SELECT MAX(english), MIN(math) FROM exam_result;

七、Group By 分组查询

统计每个部门的平均工资和最高工资:

SELECT deptno, AVG(sal), MAX(sal) FROM EMP GROUP BY deptno;

总结

  • Create:插入单条、多条数据,支持冲突更新与替换。
  • Retrieve:利用 SELECT 搭配 WHEREORDER BYLIMIT 实现各种查询。
  • Update:可更新单列、多列,支持表达式运算。
  • Delete:可删除部分或全部数据,TRUNCATE 更高效但不可回滚。
  • 聚合与分组:结合 COUNTSUMAVGMAXMINGROUP BY 实现统计分析。

熟练掌握这些基本操作,就能为复杂的 SQL 开发打下坚实基础。

http://www.wxhsa.cn/company.asp?id=3903

相关文章:

  • 202109_鹤城杯_SQL注入
  • Madness - TryHackMe
  • hahasim 香港手机卡 没信号 解决
  • 机器人逆运动学进阶:李代数、矩阵指数与旋转流形计算
  • 第一周博文
  • HTML基础
  • CSP-S模拟21
  • 【System Beats!】第二章 信息的表示与处理
  • ZR 25 noip D3T2 题解 | 构造、数学
  • 9. LangChain4j + 整合 Spring Boot - Rainbow
  • gcc
  • 在企业内部分发 iOS App 时如何生成并应用 manifest.plist
  • CSP2025 游记
  • Luogu P14031 【MX-X20-T5】「FAOI-R7」连接时光 II
  • 第一周预习作业
  • 计算机大数据毕业设计推荐:基于Spark的新能源汽车保有量可视化分析系统 - 指南
  • csp 2025 油迹
  • 完整教程:JMeter基本介绍
  • []
  • rv
  • Source Insight 4.0安装和使用教程
  • EF Core 介绍与入门实操
  • jdk8.0中导入新证书
  • ORA-00800
  • 50期权日内交易技巧 - 指南
  • 使用overleaf编写中文
  • 9.13 CSP-S模拟21 改题记录
  • Vulkan API 创建并渲染一个辐照度立方体贴图,用于 PBR 光照计算
  • 使用Putty远程连接树莓派5提示No supported authentication methods available
  • [USACO24FEB] Maximizing Productivity