DML语言:
数据操纵语言:插入:insert 修改:update 删除:delete
一:插入语句
语法:insert into 表名(列名.....) values(值1,......)
语法:insert into 表名 set 字段=值,,,,
二:修改语句:
1.修改单表的记录
语法:update 表名 set 列=新值,列=新值,,,,where 筛选条件
2.修改多表的记录【补充】
语法:
sql92
update 表1 别名,表2 别名
set 列=值,,,,,
where 连接条件
and 筛选条件
sql99
update 表1 别名
inner|left|right join 表2 别名
on 连接条件
set 列=值,,,,,
where 筛选条件
案例1:修改张无忌的女朋友的手机号为114
update boys bo
inner join beauty b on bo.id=b.boyfriend_id
set b.phone='114'
where bo.boyName='张无忌'
select * from beauty
案例2,修改没有男朋友的女神的男朋友为2号
update boys bo RIGHT JOIN beauty b on bo.id=b.boyfriend_id
set b.boyfriend_id='2'
where b.boyfriend_id is null;
三:删除语句
方式一:delete
语法:
1:单表的删除
delete from 表名 where 筛选条件
2.多表的删除【补充】
sql92语法:
delete 表1的别名,表2的别名
from 表1 别名,表2 别名
where 连接条件
and 筛选条件
sql99
delete 表1的别名,表2的别名
from 表1 别名
inner|left|right join 表2 别名 on 连接条件
where 筛选条件
方式二:TRUNCATE
语法:TRUNCATE TABLE 表名;效率要比delete高
案例;删除张无忌的女朋友的信息
delete b
from beauty b
inner join boys bo on b.boyfriend_id=bo.id
where bo.boyName ='张无忌';
案例:删除黄晓明的信息和他女朋友的信息
delete b,bo
from beauty b
inner join boys bo on b.boyfriend_id=bo.id
where bo.boyName ='黄晓明';--这就是级联删除
面试题
总结:假如要删除的表中有自增长列,如果用delete删除后,再插入数据,自增长列的值从断点开始,而trucate删除之后,再插入数据,自增长列的值从1开始
使用delete删除之后,是有返回值的,返回你一共删除了多少行,
如果使用truncate删除,是没有返回值的,你会看到运行结果显示为删除了0行
truncate删除之后不能进行回滚,delete删除之后能够进行回滚,(注意:truncate清掉表中数据,但是表的结构是还存在的)。