Accpcjg 2020-02-22
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 b.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删除之后能够进行回滚