『 MySQL数据库 』CRUD之UD,表的数据更新(修改)及删除

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: 『 MySQL数据库 』CRUD之UD,表的数据更新(修改)及删除



🥩 Update (更新/修改) 🦖

该语法主要针对于对数据库的表内数据进行修改;

一般该操作需要配合条件筛选,否则操作将影响整张表;

语法:

UPDATE table_name SET column = expr[,column = expr ... ]
[WHERE ...] [ORDER BY ...] [LIMIT ...]

存在一张表:

+----+---------+---------+------+---------+
| id | name    | chinese | math | english |
+----+---------+---------+------+---------+
|  1 | Lihua   |      67 |   88 |      90 |
|  2 | Liming  |      57 |   58 |      70 |
|  3 | Zhaolao |      66 |   80 |      47 |
|  4 | Wu      |      76 |   70 |      47 |
|  5 | Wuqi    |      88 |   43 |      80 |
|  6 | Liqiang |      89 |   92 |      90 |
|  7 | Qinsu   |      90 |   74 |      67 |
|  8 | Zhaoli  |      54 |   74 |     100 |
+----+---------+---------+------+---------+

🥚 修改单行数据的某个字段内的数据 🦕

示例:将name字段为Lihua的chinese字段数据修改为100

mysql> select name,chinese from Point where name ='Lihua';# 打印数据进行观察
+-------+---------+
| name  | chinese |
+-------+---------+
| Lihua |      67 |
+-------+---------+
1 row in set (0.00 sec)
mysql> update Point set chinese=100 where name='Lihua';# 修改数据
Query OK, 1 row affected (0.00 sec)
Rows matched: 1  Changed: 1  Warnings: 0
mysql> select name,chinese from Point where name ='Lihua';# 打印数据进行观察
+-------+---------+
| name  | chinese |
+-------+---------+
| Lihua |     100 |
+-------+---------+
1 row in set (0.00 sec)

也可对单行数据的多个字段数据进行修改,前提是这个数据具有唯一属性(体现了主键约束的重要性);


🥚 配合LIMIT分页与ORDER BY 对符合条件的多条数据进行修改 🦕

示例:将字段条件chinese+math+english前3大的数据中的math字段数据+30

# 打印数据进行查看 -- 修改前
mysql> select name,math from Point order by math+chinese+english desc limit 3;
+---------+------+
| name    | math |
+---------+------+
| Lihua   |   88 |
| Liqiang |   92 |
| Qinsu   |   74 |
+---------+------+
3 rows in set (0.00 sec)
mysql> select name,math+chinese+english from Point order by math+chinese+english desc limit 3;
+---------+----------------------+
| name    | math+chinese+english |
+---------+----------------------+
| Lihua   |                  278 |
| Liqiang |                  271 |
| Qinsu   |                  231 |
+---------+----------------------+
3 rows in set (0.00 sec)
# 修改数据
mysql> update Point set math=math+30 order by math+chinese+english desc limit 3;
Query OK, 3 rows affected (0.00 sec)
Rows matched: 3  Changed: 3  Warnings: 0
# 打印数据进行查看 -- 修改后
mysql> select name,math+chinese+english from Point order by math+chinese+english desc limit 3;
+---------+----------------------+
| name    | math+chinese+english |
+---------+----------------------+
| Lihua   |                  308 |
| Liqiang |                  301 |
| Qinsu   |                  261 |
+---------+----------------------+
3 rows in set (0.00 sec)
mysql> select name,math from Point order by math+chinese+english desc limit 3;
+---------+------+
| name    | math |
+---------+------+
| Lihua   |  118 |
| Liqiang |  122 |
| Qinsu   |  104 |
+---------+------+

当需要修改的数据条件繁琐的前提可以先使用SELECT FROM语句先对需要修改的数据进行查看筛选,再对该SELECT FROM语句根据筛选条件修改为对应的UPDATE SET语句对数据进行修改!


🥚 对整表的某个数据字段进行修改 🦕

UPDATE SET语句中若是没有用WHERE语句进行筛选则更新整表!

在SQL中对整表的操作需要慎重;

示例:将整表中的english字段数据修改为 *=2 ;

# 使用SELECT FROM语句对数据进行查看 -- 修改前
mysql> select id,name,english from Point;
+----+---------+---------+
| id | name    | english |
+----+---------+---------+
|  1 | Lihua   |      90 |
|  2 | Liming  |      70 |
|  3 | Zhaolao |      47 |
|  4 | Wu      |      47 |
|  5 | Wuqi    |      80 |
|  6 | Liqiang |      90 |
|  7 | Qinsu   |      67 |
|  8 | Zhaoli  |     100 |
+----+---------+---------+
8 rows in set (0.00 sec)
# 对数据进行修改
mysql> update Point set english*=2 ; #SQL语句中不支持*=,+=等语法!
ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '*=2' at line 1# error
mysql> update Point set english=english*2 ;# 正确
Query OK, 8 rows affected (0.01 sec)
Rows matched: 8  Changed: 8  Warnings: 0
# 使用SELECT FROM语句对数据进行查看 -- 修改后
mysql> select id,name,english from Point;
+----+---------+---------+
| id | name    | english |
+----+---------+---------+
|  1 | Lihua   |     180 |
|  2 | Liming  |     140 |
|  3 | Zhaolao |      94 |
|  4 | Wu      |      94 |
|  5 | Wuqi    |     160 |
|  6 | Liqiang |     180 |
|  7 | Qinsu   |     134 |
|  8 | Zhaoli  |     200 |
+----+---------+---------+
8 rows in set (0.00 sec)

🥩 Delete (删除数据) 🦖

该语句一般用于对某条数据的删除,也可以删除整表的数据;

语法:

DELETE FROM table_name [WHERE ...] [ORDER BY ...] [LIMIT ...]

存在一张表(to_del):

+-----+-----------+
| id  | name      |
+-----+-----------+
| 001 | Lihua     |
| 002 | Liming    |
| 003 | Zhangchao |
| 004 | Zhaoli    |
| 005 | Lili      |
+-----+-----------+

🥚 删除单条数据 🦕

示例:删除id字段为2的数据

mysql> select * from to_del
    -> ;
+-----+-----------+
| id  | name      |
+-----+-----------+
| 001 | Lihua     |
| 002 | Liming    |
| 003 | Zhangchao |
| 004 | Zhaoli    |
| 005 | Lili      |
+-----+-----------+
5 rows in set (0.00 sec)
mysql> delete from to_del where id=2;
Query OK, 1 row affected (0.00 sec)
mysql> select * from to_del;
+-----+-----------+
| id  | name      |
+-----+-----------+
| 001 | Lihua     |
| 003 | Zhangchao |
| 004 | Zhaoli    |
| 005 | Lili      |
+-----+-----------+
4 rows in set (0.00 sec)

🥚 删除整表数据 🦕

UPDATE SET语句相同,DELETE FROM语句也可以删除整表的数据;

-- 查看表内数据 删除前
mysql> select * from to_del;
+-----+-----------+
| id  | name      |
+-----+-----------+
| 001 | Lihua     |
| 003 | Zhangchao |
| 004 | Zhaoli    |
| 005 | Lili      |
+-----+-----------+
4 rows in set (0.00 sec)
-- 删除整表数据 
mysql> delete from to_del;
Query OK, 4 rows affected (0.00 sec)
-- 查看表内数据 删除后
mysql> select * from to_del;
Empty set (0.00 sec)

🥚 截断表 (TRUNCATE) 🦕

语法:

TRUNCATE [TABLE] table_name;

截断表的操作与删除整表的作用类似也为清除整表内容(不作示例);

但存在不同;

同样以该表进行测试;

+-----+-----------+
| id  | name      |
+-----+-----------+
| 001 | Lihua     |
| 002 | Liming    |
| 003 | Zhangchao |
| 004 | Zhaoli    |
| 005 | Lili      |
+-----+-----------+
  • 使用SHOW CREATE TABLE table_name \G 对表的详细信息进行查看;
mysql> show create table to_del\G
*************************** 1. row ***************************
       Table: to_del
Create Table: CREATE TABLE `to_del` (
`id` int(3) unsigned zerofill NOT NULL AUTO_INCREMENT COMMENT 'id增加主键约束',
`name` varchar(20) NOT NULL COMMENT 'name增加唯一键约束',
PRIMARY KEY (`id`),
UNIQUE KEY `name` (`name`)
) ENGINE=MyISAM AUTO_INCREMENT=6 DEFAULT CHARSET=utf8
1 row in set (0.00 sec)
  • 对该表进行查看时自增AUTO_INCREMENT关键字为6;
  • 使用DELETE FROM删除整表;
mysql> delete from to_del;
Query OK, 5 rows affected (0.01 sec)
mysql> show create table to_del\G
*************************** 1. row ***************************
     Table: to_del
Create Table: CREATE TABLE `to_del` (
`id` int(3) unsigned zerofill NOT NULL AUTO_INCREMENT COMMENT 'id增加主键约束',
`name` varchar(20) NOT NULL COMMENT 'name增加唯一键约束',
PRIMARY KEY (`id`),
UNIQUE KEY `name` (`name`)
) ENGINE=MyISAM AUTO_INCREMENT=6 DEFAULT CHARSET=utf8
1 row in set (0.00 sec)
  • 使用DELETE FROM对整表进行删除时其AUTO_INCREMENT关键字并没有改变;
  • 使用TRUNCATE对整表进行截断操作;
mysql> truncate to_del;
Query OK, 0 rows affected (0.00 sec)
mysql> show create table to_del\G
*************************** 1. row ***************************
     Table: to_del
Create Table: CREATE TABLE `to_del` (
`id` int(3) unsigned zerofill NOT NULL AUTO_INCREMENT COMMENT 'id增加主键约束',
`name` varchar(20) NOT NULL COMMENT 'name增加唯一键约束',
PRIMARY KEY (`id`),
UNIQUE KEY `name` (`name`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8
1 row in set (0.00 sec)
  • 使用TRUNCATE对表进行截断操作时此时该表的AUTO_INCREMENT关键字不见了;

综上所述可以确定:

1. TRUNCATE只能对整表进行操作,且不能像DELETE对部分数据进行操作;

2. 若是表中存在AUTO_INCREMENT自增约束时,TRUNCATE的截断表操作将会重置AUTO_INCREMENT;

除此之外,对于DELETE来说,TRUNCATE的删除操作会较快,因为TRUNCATE在操作删除数据时并不经过真正的事务,所以无法回滚;


🥩 总结 🦖🦖🦖🦖🦖

对于对表内数据的操作来说,无论是UPDATE还是DELETETRUNCATE对整表进行操作都应该注意;

尽量在对表内数据修改或删除前对需要修改\删除的数据使用 SELETC进行查看,避免误操作;

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
12天前
|
SQL 存储 关系型数据库
MySQL/SqlServer跨服务器增删改查(CRUD)的一种方法
通过上述方法,MySQL和SQL Server均能够实现跨服务器的增删改查操作。MySQL通过联邦存储引擎提供了直接的跨服务器表访问,而SQL Server通过链接服务器和分布式查询实现了灵活的跨服务器数据操作。这些技术为分布式数据库管理提供了强大的支持,能够满足复杂的数据操作需求。
55 12
|
7月前
|
关系型数据库 MySQL 数据库
数据迁移脚本优化过程:从 MySQL 到 Django 模型表
在大规模的数据迁移过程中,性能问题往往是开发者面临的主要挑战之一。本文将分析一个数据迁移脚本的优化过程,展示如何从 MySQL 数据库迁移数据到 Django 模型表,并探讨优化前后的性能差异。
|
3月前
|
数据可视化 API PHP
学生信息管理系统-可视化-科目管理CRUD代码生成器
学生信息管理系统-可视化-科目管理CRUD代码生成器
53 5
|
4月前
|
关系型数据库 MySQL 数据库
MySQL 表的CRUD与复合查询
【9月更文挑战第26天】本文介绍了数据库操作中的 CRUD(创建、读取、更新、删除)基本操作及复合查询。创建操作使用 `INSERT INTO` 语句插入数据,支持单条和批量插入;读取操作使用 `SELECT` 语句查询数据,可进行基本查询、条件查询和排序查询;更新操作使用 `UPDATE` 语句修改数据;删除操作使用 `DELETE FROM` 语句删除数据。此外,还介绍了复合查询,包括连接查询(如内连接、左连接)和子查询,以及聚合函数与分组查询,并提供了示例代码。
|
4月前
|
前端开发 IDE 数据库连接
ThinkPHP6 模型层的模型属性,表映射关系,以及如何在控制层中使用模型层和模型层中的简单CRUD
本文详细介绍了ThinkPHP6中模型层的使用,包括模型属性设置、表映射关系、以及如何在控制层中使用模型层进行CRUD操作。
ThinkPHP6 模型层的模型属性,表映射关系,以及如何在控制层中使用模型层和模型层中的简单CRUD
|
5月前
|
API Python
[gin]基于切片实现crud
[gin]基于切片实现crud
|
5月前
|
SQL 数据处理 数据库
SQL进阶之路:深入解析数据更新与删除技巧——掌握批量操作、条件筛选、子查询和事务处理,提升数据库维护效率与准确性
【8月更文挑战第31天】在数据库管理和应用开发中,数据的更新和删除至关重要,直接影响数据准确性、一致性和性能。本文通过具体案例,深入解析SQL中的高级更新(UPDATE)和删除(DELETE)技巧,包括批量更新、基于条件的删除以及使用子查询和事务处理复杂场景等,帮助读者提升数据处理能力。掌握这些技巧能够有效提高数据库性能并确保数据一致性。
105 0
|
5月前
|
前端开发 Java 关系型数据库
通过HTML网页对mysql数据库进行增删改查(CRUD实例)
通过HTML网页对mysql数据库进行增删改查(CRUD实例)
336 0
|
6月前
|
存储 数据处理 数据库
数据库索引策略如何影响数据更新操作的性能?
【7月更文挑战第3天】数据库索引策略如何影响数据更新操作的性能?
105 1
|
6月前
|
存储 SQL 关系型数据库
MySQL设计规约问题之在数据库设计中,为什么要适当考虑反范式的表设计
MySQL设计规约问题之在数据库设计中,为什么要适当考虑反范式的表设计