MySQL 插入,修改,删除数据,清空表记录

本文详细介绍了MySQL中如何使用INSERT语句插入数据,包括INSERT…VALUES和INSERT…SET两种方法。此外,还讲解了如何通过UPDATE语句修改数据,以及利用DELETE语句删除数据。在删除数据时,对比了DELETE与TRUNCATE的区别,提醒读者在大量删除数据时考虑使用TRUNCATE以提高效率。最后,提到了数据操作的安全性,如DELETE支持事务回滚,而TRUNCATE不支持。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

插入数据

数据库和表创建成功之后就要向数据库的表插入数据,在MySQL中就是用 INSERT语句插入一行或者多行数据。插入数据有两种方法,INSERT…VALUES 语句和 INSERT…SET 语句。

INSERT…VALUES 语法

INSERT INTO <表名> [ <列名1>  ,, <列名n>] VALUES (1) ,, (值n);
  1. 表名是被操作的表名。
  2. 列名是指要指定需要插入数据的列名,列名用括号包着,如果要向表中的所有列插入数据,则列名可以省略,只写个表名。
  3. VALUES 是要插入数据的清单,清单的数据要和列名顺序一样,类型也要一样,也可以插入多行,但要在圆括号之间用逗号隔开。

INSERT…SET语法

INSERT INTO 表名  SET 列名1 =1,...,列名n = 值n, 

此语句用于向指定的列中插入数据,而未对于指定的列,则会指定的该列的默认值。

INSERT INTO…SELECT… FROM 赋值表数据

INSERT INTO 表名1 SELECT  列名  FROM  表名2
  1. 表名1是指要插入的表
  2. 列名是要从被复制的表中提取的列名,如果全部提取则直接用 *。
  3. FROM 要从另一个表中获取数据的表名。

注意: 在赋值数据到另一个表中,必须两个表中的列要对应,数据类型也要一样。

修改数据

修改数据也称更新数据,可以更新一个或者多个表的数据。

UPDATE 表名 SET 列名 1=1,...,列名 n=值n ;
  1. 表名是要被修改的表。
  2. 列名是要被修改的列,可以对多个列修改。

注意: 这种修改形式直接将列下面对应的所有数据都修改成一样的。

根据条件修改表中的数据

WHERE 子句用来指定被修改的数据的条件。

UPDATE 表名 SET 列名 1=1,...,列名 n=值n WHERE 表达式;

删除数据

DELETE语句可以删除表中的一行或都多行数据。

DELETE FROM 表名 WHERE 表达式 
  1. 表名是要被删除的表
  2. WHERE语句指定删除数据的条件,如果省略则要删除所有行。

清空表记录

TRUNCATE TABLE 表名

TABLE语句可以省略。

DELETE与TRUNCATE的区别

  1. DELETE 是逐行一条一条删除记录的;TRUNCATE 则是直接删除原来的表,再重新创建一个一模一样的新表,而不是逐行删除表中的数据,执行数据比 DELETE 快。因此需要删除表中全部的数据行时,尽量使用 TRUNCATE 语句, 可以缩短执行时间。
  2. DELETE 删除数据后,配合事件回滚可以找回数据;TRUNCATE 不支持事务的回滚,数据删除后无法找回。
  3. DELETE 删除数据后,系统不会重新设置自增字段的计数器;TRUNCATE 清空表记录后,系统会重新设置自增字段的计数器。
  4. DELETE 的使用范围更广,因为它可以通过 WHERE 子句指定条件来删除部分数据;而 TRUNCATE 不支持 WHERE 子句,只能删除整体。
  5. DELETE 会返回删除数据的行数,但是 TRUNCATE 只会返回 0,没有任何意义。
### MySQL 数据插入修改删除操作详解 #### 一、数据插入操作 在 MySQL 中,`INSERT INTO` 语句用于向插入新记。可以通过指定列名的方式插入部分字段的数据,也可以不指定列名而直接插入所有字段的值。 以下是两种常见的 `INSERT INTO` 使用方式: 1. **指定列名并插入数据** ```sql INSERT INTO 名 (列1, 列2, ...) VALUES (值1, 值2, ...); ``` 这种方式适用于仅需插入部分字段的情况[^2]。 2. **插入全部字段的数据** 如果要插入所有字段的数据,则可以直接省略列名: ```sql INSERT INTO 名 VALUES (值1, 值2, ...); ``` 需要注意的是,在这种情况下,值的数量和顺序必须与定义完全一致[^4]。 对于批量插入数据,可以一次性插入多条记以提升效率: ```sql INSERT INTO 名 (列1, 列2, ...) VALUES (值1_1, 值1_2, ...), (值2_1, 值2_2, ...), ...; ``` 此外,还可以通过子查询实现跨数据复制: ```sql INSERT INTO new_goods(id, type, name, price, num, add_time) SELECT id, type, name, price, num, add_time FROM goods; ``` 此方法可用于将现有中的数据迁移到另一个结构相似的新中[^3]。 --- #### 二、数据修改操作 当需要更改已存在的记时,可使用 `UPDATE` 语句。其基本语法如下: ```sql UPDATE 名 SET 列1=新值1, 列2=新值2,... WHERE 条件达式; ``` 其中,`WHERE` 子句用于限定哪些记会被更新;如果忽略该条件,则会更新整个的所有记[^1]。 例如,假设有一个名为 `users` 的,现在想把 ID 为 5 的用户的邮箱地址更改为新的值: ```sql UPDATE users SET email='new_email@example.com' WHERE id=5; ``` 注意:为了避免误操作导致大量不必要的改动,在执行前应仔细确认 `WHERE` 条件是否准确无误。 --- #### 三、数据删除操作 若希望从数据库中移除某些特定记或者清空整张的内容,应该采用 `DELETE` 或者 `TRUNCATE` 语句完成这一目标。 - **单条或多条记删除** 当只需要删除满足一定条件的部分行时,适用以下形式: ```sql DELETE FROM 名 WHERE 条件达式; ``` 如下例子展示了如何依据年龄筛选出大于等于60岁的人员予以剔除: ```sql DELETE FROM employees WHERE age >= 60; ``` - **全数据清除** 若打算快速彻底地抹去某内的所有资料而不保留任何残留项的话,推荐运用更为高效的命令——`TRUNCATE TABLE`: ```sql TRUNCATE TABLE 名; ``` 它不仅速度更快而且还能重置自增计数器回到初始状态,不过需要注意一点就是无法附加额外过滤逻辑因此作用范围仅仅局限于整体而非局部区域而已。 --- ### 总结 综上所述,掌握了上述三种基础却极其重要的 DML(Data Manipulation Language) 功能之后便能够灵活自如地操控关系型数据库内部所保存的信息资源了。无论是新增加项目还是调整已有属性亦或是淘汰过期对象都能得心应手轻松搞定!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值