MySql列的插入,修改和删除

本文详细介绍了MySQL中数据操作语言DML,包括插入(insert)、修改(update)和删除(delete)语句的不同用法。通过案例展示了如何执行简单到复杂的操作,如插入默认值、不按顺序插入、多行插入、子查询插入、单表及多表修改,以及单表和多表删除。同时提到了delete与truncate的区别,以及它们在事务回滚上的不同行为。
摘要由CSDN通过智能技术生成
DML语言

– 数据操作语言
– 插入:insert
– 修改:update
– 删除:delete

一:插入语句
方式1:

– 语法:
– insert into 表名(列名,…) values(值1,…)

案例1:简单使用
INSERT INTO beauty(id,NAME,sex,borndate,phone,photo,boyfriend_id)
VALUES(20,'张三','女','1922-2-12','21232132',NULL,21);
SELECT * FROM beauty;
案例2:有nullable属性的列名可以不写,插入默认值;插入时可以不按顺序
INSERT INTO beauty(NAME,id,phone)
VALUES('张四',21,'212321322');
SELECT * FROM beauty;
案例3:表后面的括号和列名可以不写,默认为表里面的所有列,顺序不能变
INSERT INTO beauty
VALUES(22,'张五','女','1922-2-12','21232132',NULL,21);
SELECT * FROM beauty;
案例4:支持插入多行
INSERT INTO beauty
VALUES(26,'张三','女','1922-2-12','21232132',NULL,21),
(24,'张三','女','1922-2-12','21232132',NULL,21),
(25,'张三','女','1922-2-12','21232132',NULL,21);
SELECT * FROM beauty;
案例5:支持子查询
INSERT INTO beauty(id,NAME,phone)
SELECT 98,'12','2123' UNION
SELECT 45,'12','2123';
方式2:

– 语法:
INSERT INTO 表名 SET 列名=值,列名=值,…

案例1:简单使用
INSERT INTO beauty SET id=23,NAME='张柳',phone='12332312321';
SELECT * FROM beauty;
二:修改语句

– 1.修改单表的语法:
– update 表 set 列名=新值,列表=新值,…
– where 筛选条件

案例1:
UPDATE beauty SET phone='123456789'
WHERE id=9;

– 2.修改多表语法:(并非修改多个表,而是通过连接表来修改某个表)
– sql92:(只支持内连接)
– update 表1 别名,表2 别名
– set 列=值…
– where 连接条件
– and 筛选条件
– sql99:
– update 表1 别名
– inner|left|right join 表2 别名
– on 连接条件
– set 列=值…
– where 筛选条件

案例1:
UPDATE boys bo
INNER JOIN beauty b ON bo.`id`=b.`boyfriend_id`
SET phone='1'
WHERE bo.`boyName` LIKE '%张%';
案例2:
UPDATE boys bo
RIGHT JOIN beauty b ON b.`boyfriend_id`=bo.id
SET boyfriend_id=2
WHERE bo.id IS NULL;
三:删除语句

– 方式一:delete 删除行
– 语法:
– delete from 表名 where 筛选条件
– delete from 表名 连接类型 join 表名 on 连接条件 where 筛选条件(sql99)

案例:单表删除
DELETE FROM beauty WHERE phone LIKE '%9';
案例:多表删除
DELETE b 
FROM  beauty b 
INNER JOIN boys bo
ON bo.id=b.`boyfriend_id`
WHERE bo.boyname LIKE '%张%';

– 方式二:truncate 删除表
– 语法:
– truncate table 表名

案例:
TRUNCATE TABLE boys;
注意点

– 如果用delete删除后,再插数据,自增长列的值会是1个新值.用truncate删除则不是.
– delete有返回值,truncate无;
– truncate删除不能回滚,delete删除可以回滚

### 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、付费专栏及课程。

余额充值