插入
方式一
语法:
insert into 表名(字段名,...)
values(值,...);
特点:
- 要求值的类型和字段的类型要一致或兼容
- 字段的个数和顺序不一定与原始表中的字段个数和顺序一致 但必须保证值和字段一一对应
- 假如表中有可以为null的字段,注意可以通过以下两种方式插入null值 ①字段和值都省略 ②字段写上,值使用null
- 字段和值的个数必须一致
- 字段名可以省略,默认所有列
方式二
语法:
insert into 表名
set 字段=值,字段=值,...;
两种方式的区别:
- 方式一支持一次插入多行,语法如下:
insert into 表名【(字段名,..)】 values(值,..),(值,...),...;
- 方式一支持子查询,语法如下:
insert into 表名
查询语句;
修改
修改单表的记录
语法:
update 表名
set 字段=值,字段=值
【where 筛选条件】;
修改多表的记录
语法:
update 表1 别名
left|right|inner join 表2 别名
on 连接条件
set 字段=值,字段=值
【where 筛选条件】;
删除
方式一:使用delete
- 删除单表的记录
**语法:**delete from 表名 【where 筛选条件】【limit 条目数】
- 级联删除[补充]
语法:
delete 别名1,别名2
from 表1 别名
inner|left|right join 表2 别名
on 连接条件
【where 筛选条件】
方式二:使用truncate
**语法:**truncate table 表名
两种方式的区别【面试题】
- truncate删除后,如果再插入,标识列从1开始
delete删除后,如果再插入,标识列从断点开始
- delete可以添加筛选条件
truncate不可以添加筛选条件
- truncate效率较高
- truncate没有返回值
delete可以返回受影响的行数
- truncate不可以回滚
delete可以回滚
注:本文借鉴了尚硅谷公开课的内容,若有错误或不妥之处还望提醒。