news 2026/4/23 10:10:10

MySQL 实战:表数据维护核心技能(插入 / 更新 / 删除全解析)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
MySQL 实战:表数据维护核心技能(插入 / 更新 / 删除全解析)

在上一篇数据库与数据表管理的基础上,本次实验聚焦表数据的核心维护操作 —— 插入、更新与删除。数据维护是数据库日常使用中最频繁的场景,无论是批量录入数据、修正错误信息,还是清理无效记录,都需要熟练掌握对应的 SQL 语法。本文将通过实操案例,拆解 MySQL 数据维护的关键技巧,帮你轻松搞定数据增删改!

一、实验核心目标

  1. 掌握单条数据、多条数据的插入方法,包括完整字段插入和指定字段插入
  2. 学会灵活更新表数据,精准定位目标记录(避免批量误改)
  3. 熟练使用删除语句清理指定记录、清空表数据,理解不同删除方式的差异
  4. 结合多表场景,实现数据维护的综合应用

二、核心知识点与实操详解

(一)数据插入:INSERT 语句的 3 种实用场景

INSERT 语句是向表中添加数据的核心,支持单条插入、批量插入、指定字段插入,满足不同业务需求。

1. 环境准备:创建数据库与数据表

先搭建实验环境,创建 yygl 数据库和 emp 表(员工表)、salary 表(薪资表):

sql

-- 创建yygl数据库并选择 CREATE DATABASE yygl; USE yygl; -- 创建emp表(员工信息表) CREATE TABLE emp( empno char(4) NOT NULL PRIMARY KEY, -- 员工编号,主键非空 ename varchar(10), -- 员工姓名 job varchar(10), -- 职位 hiredate date, -- 入职日期 deptno char(3) -- 部门编号 ); -- 创建salary表(薪资表) CREATE TABLE salary( empno char(4) NOT NULL PRIMARY KEY, -- 员工编号,与emp表关联,主键非空 income float, -- 收入 outcome float -- 支出 );
2. 插入数据的 3 种方式
(1)完整字段单条插入

指定所有字段的值,字段顺序需与表结构一致:

sql

-- 插入emp表第一行数据(完整字段) INSERT INTO emp VALUES('7369','SMITH','CLERK','2005-10-1','20');
(2)完整字段批量插入

用逗号分隔多条记录,一次执行插入多条数据,效率更高:

sql

-- 批量插入emp表后三行数据 INSERT INTO emp VALUES ('7499','ALLEN','SALESMAN','2000-05-01','30'), ('7521','WARD','SALESMAN','2010-06-17','30'), ('7566','JONE','MANAGER','2000-04-23','20');
(3)指定字段插入

只插入部分必填字段,未指定的字段若允许为空则显示 NULL:

sql

-- 仅插入empno和ename字段,其他字段留空 INSERT INTO emp(empno,ename) VALUES('7788','SCOTT');
3. 薪资表数据插入(实操示例)

sql

-- 向salary表插入4条薪资数据 INSERT INTO salary VALUES ('7369',8000,1320), ('7499',12000,1463), ('7521',11500,1463), ('7566',13000,1566);

(二)数据更新:UPDATE 语句精准修改

UPDATE 用于修改表中已有数据,核心是通过 WHERE 子句定位目标记录,否则会误改全表数据!

1. 基础语法

sql

UPDATE 表名 SET 字段1=值1, 字段2=值2 WHERE 条件;
2. 实操案例
(1)修改指定员工的职位和入职日期

sql

-- 将empno为7788的SCOTT职位改为ANALYST,入职日期改为2007-02-10 UPDATE emp SET job='ANALYST',hiredate='2007-02-10' WHERE empno='7788';
(2)计算并更新薪资字段

先为 salary 表增加 sal(净收入)字段,再通过表达式计算值:

sql

-- 为salary表增加sal字段(净收入) ALTER TABLE salary ADD sal float; -- 计算sal=income-outcome,并更新到每行 UPDATE salary SET sal=income-outcome;
3. 避坑提示
  • MySQL 默认开启SQL_SAFE_UPDATES=1(安全更新模式),禁止无 WHERE 条件的更新,若需批量更新可临时关闭:

    sql

    SET SQL_SAFE_UPDATES=0; -- 关闭安全模式(操作后可重新开启为1)
  • WHERE 条件尽量使用主键(如 empno)或唯一字段,确保修改目标精准

(三)数据删除:DELETE 与 TRUNCATE 的区别与应用

删除数据分为 “删除指定记录”“清空全表” 两种场景,对应 DELETE 和 TRUNCATE 两个命令,用法和效果差异较大。

1. 删除指定记录(DELETE)

sql

-- 删除deptno为30的部门员工记录 DELETE FROM emp WHERE deptno='30'; -- 删除salary表中income在8000-10000(含边界)的记录 DELETE FROM salary WHERE income BETWEEN 8000 AND 10000;
2. 清空全表数据(两种方式对比)
命令语法特点适用场景
DELETEDELETE FROM 表名;逐行删除,可回滚,保留表结构和自增序列需保留表结构,可能后续恢复数据
TRUNCATETRUNCATE TABLE 表名;快速清空,不可回滚,重置自增序列彻底清空表数据,无需保留历史

实操示例

sql

-- 清空emp表所有记录(TRUNCATE方式) TRUNCATE TABLE emp;
3. 高级删除:删除表与数据库

数据维护完成后,可删除临时表或数据库(谨慎操作!):

sql

-- 删除salary表 DROP TABLE salary; -- 删除YGGL数据库 DROP DATABASE YGGL;

(四)综合实操:数据维护完整流程

结合上述知识点,完成从数据插入到最终清理的全流程:

  1. 创建数据库和表:CREATE DATABASE yygl; USE yygl; CREATE TABLE emp(...);
  2. 插入数据:单条插入、批量插入、指定字段插入
  3. 更新数据:修改指定记录、通过表达式计算更新字段
  4. 删除数据:删除指定条件记录、清空全表
  5. 清理环境:删除表和数据库

三、实验总结与避坑指南

  1. 插入数据注意事项:

    • 字段值与数据类型匹配(如 date 类型需符合 YYYY-MM-DD 格式)
    • 主键不可重复,非空字段必须赋值
    • 批量插入比单条插入效率更高,大数据量推荐使用
  2. 更新数据核心原则:

    • 永远不要省略 WHERE 子句(除非确实需要更新全表)
    • 多字段更新用逗号分隔,赋值符号用=(不是==
    • 修改前可先执行 SELECT 语句验证条件是否正确(如SELECT * FROM emp WHERE empno='7788';
  3. 删除数据关键区别:

    • DELETE 是 DML 语句,可通过事务回滚;TRUNCATE 是 DDL 语句,不可回滚
    • TRUNCATE 清空后自增字段会重置为初始值,DELETE 不会
    • DROP TABLE/DATABASE 会删除表 / 库结构,数据完全不可恢复,务必谨慎
  4. 常用技巧:

    • 插入部分字段时,明确指定字段名(可读性更强,避免表结构变更导致错误)
    • 数值范围查询用BETWEEN...AND...(如收入 8000-10000)
    • 临时关闭安全更新模式后,记得及时开启,避免误操作

数据维护是 MySQL 实战的基础,掌握 INSERT、UPDATE、DELETE 的灵活运用,能解决大部分日常数据处理需求。建议多结合实际场景练习(比如模拟员工信息录入、薪资调整、离职人员清理),加深对语法的理解和记忆。如果在操作中遇到问题,欢迎在评论区交流讨论!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 2:49:46

冥想第一千七百三十七天(1737)

1.很快就又周四了,感觉像周二的感觉,今天休息日,总算稍微松口气的一天。下班了去游泳。 2.感谢父母,感谢朋友,感谢家人,感谢不断进步的自己。

作者头像 李华
网站建设 2026/4/22 18:37:20

手撕call/apply/bind:从ES6用法到手写实现,吃透this指向核心

🔥 手撕call/apply/bind:从ES6用法到手写实现,吃透this指向核心 在JavaScript中,this 指向的绑定是前端开发绕不开的核心知识点,而 call、apply、bind 作为改变函数执行上下文的“三剑客”,既是解决 this 丢…

作者头像 李华
网站建设 2026/4/19 14:21:12

HTR3355 I2C/SMBus IO扩展器全方位解析

在电子系统集成化、小型化的发展趋势下,GPIO端口资源紧张已成为众多硬件设计的共性难题。HTR3355作为一款专为I2C和SMBus总线设计的高性能IO扩展器,凭借其宽电压适配、灵活配置、功能完备等核心优势,能够高效弥补主控芯片IO端口不足的短板&am…

作者头像 李华
网站建设 2026/4/22 14:56:02

【完整源码+数据集+部署教程】食品包装识别系统源码分享[一条龙教学YOLOV8标注好的数据集一键训练_70+全套改进创新点发刊_Web前端展示]

一、背景意义 随着全球经济的快速发展和生活水平的提高,食品消费市场日益繁荣,食品包装的多样性和复杂性也随之增加。食品包装不仅是保护食品的物理屏障,更是传递品牌形象和消费者信息的重要载体。在这一背景下,食品包装的识别与…

作者头像 李华
网站建设 2026/4/22 19:02:55

PageHelper插件

介绍 PageHelper是第三方提供的Mybatis框架中的一款功能强大、方便易用的分页插件,支持任何形式的单标、多表的分页查询。 官网:Mybatis-PageHelper/wikis/zh/HowToUse.md at master ruiqianyi/Mybatis-PageHelper GitHub 代码实现 在pom.xml引入依…

作者头像 李华