跳过正文
  1. 文章/
  2. 数据库/
  3. MySQL/
  4. MySQL基础/

4、DML数据操作语句

·647 字·2 分钟· loading · loading · ·
数据库 MySQL MySQL基础
GradyYoung
作者
GradyYoung
MySQL基础 - 点击查看当前系列文章
§ 4、DML数据操作语句 「 当前文章 」

插入
#

方式一
#

语法:

insert into 表名 (字段名,...) values (,...);

特点:

1、要求值的类型和字段的类型要一致或兼容

2、字段的个数和顺序不一定与原始表中的字段个数和顺序一致

但必须保证值和字段一一对应

3、假如表中有可以为null的字段,注意可以通过以下两种方式插入null值

①字段和值都省略

②字段写上,值使用null

4、字段和值的个数必须一致

5、字段名可以省略,默认所有列

方式二
#

语法:

insert into 表名 set 字段=,字段=,...;

两种方式的区别:
#

1.方式一支持一次插入多行,语法如下:

insert into 表名(字段名,..) values(值,..),(值,...),...;

2.方式二支持子查询,语法如下:

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 表名

两种方式的区别【面试题】
#

  1. truncate删除后,如果再插入,标识列从1开始;delete删除后,如果再插入,标识列从断点开始
  2. delete可以添加筛选条件;truncate不可以添加筛选条件
  3. truncate效率较高
  4. truncate没有返回值;delete可以返回受影响的行数
  5. truncate不可以回滚;delete可以回滚
MySQL基础 - 点击查看当前系列文章
§ 4、DML数据操作语句 「 当前文章 」