一、插入
插入使用关键字INSERT INTO,插入有两种方式:
#方式一:常用
INSERT INTO t_a
VALUES(...);
#方式二:使用set,不常用
INSERT INTO t_a
SET id=1,`name`='刘涛';
使用方式一的好处:
1️⃣方式一支持一次性插入多行数据(只需要建立一次数据库连接),且效率远远高于使用多个insert语句(一个insert语句会建立一个连接,因此insert语句很多的时候效率很低):
INSERT INTO beauty
VALUES('1','陈意涵'),('2','陈乔恩'),('3','刘亦菲');
2️⃣方式一支持将子查询的查询结果插入到表中:
INSERT INTO t_a
SELECT * FROM t_b;
二、修改
修改使用的关键字是update,update也支持连接修改:
#sql92语法:仅支持内连接
UPDATE t_1 t1,t_2 t2
SET 列=值,...
WHERE 连接条件
AND 筛选条件;
#sql99语法:支持内连接、外连接、交叉连接
UPDATE t_1 t1,
INNER|LEFT|RIGHT JOIN t_2 t2 ON 连接条件
SET 列=值,...
WHERE 筛选条件;
示例:
UPDATE boys bo
INNER JOIN beauty b ON bo.id = b.boyfriend_id
SET b.phone = '112'
WHERE bo.name = '张无忌';
三、删除
删除使用的关键字有delete和truncate,truncate只能用来清空表且清空后不能进行事务回滚,因此要慎用truncate。
DETELE FROM t WHERE 条件;
TRUNCATE TABLE t;
使用delete和truncate删除表的比较:
1️⃣若删除的表中有自增长列,使用delete删除后,在插入的数据自增长列的值从断点处开始,而使用truncate清空表后,自增长列从1开始
2️⃣truncate删除没有返回值,delete删除会返回删除的行数
3️⃣truncate删除不能回滚,delete可以回滚
删除也支持连接删除:
#sql92语法
DELETE t1,t2 #删除哪个表delete后写哪个表,不写不删
FROM t_1 t1,t_2 t2
WHERE 连接条件
AND 筛选条件;
#sql99语法
DELETE t1,t2 #删除哪个表delete后写哪个表,不写不删
FROM t_1 t1
INNER|LEFT|RIGHT JOIN t_2 t2 ON 连接条件
WHERE 筛选条件;
示例1:删除一个表的数据
DELETE b
FROM beauty b
INNER JOIN boys bo ON b.boyfriend_id = bo.id
WHERE bo.name = '张无忌';
示例2:删除两个表的数据
DELETE b,bo
FROM beauty b
INNER JOIN boys bo ON b.boyfriend_id = bo.id
WHERE bo.name = '张无忌';