四、数据库之DML

一、插入

(一)、方式一

语法:
insert into 表名(列名1,列名2...) values(1,2...);
特点:
  1. 要求值的类型和字段的类型要一致或兼容
  2. 字段的个数和顺序不一定与原始表中的字段个数和顺序一致,但必须保证值和字段一一对应
  3. 假如表中有可以为null的字段(nullable),注意可以通过以下两种方式插入null值
    • 字段和值都省略
    • 字段写上,值使用null
  4. 字段和值的个数必须一致
  5. 字段名可以省略,默认所有列,字段顺序和表中顺序一致

(二)、方式二

语法:
insert into 表名 set 字段=,字段=,...;

(三)、两种方式区别:

  1. 方式一支持一次插入多行,语法如下:
insert into 表名【(字段名,..)values(值,..),(值,...),...;
  1. 方式一支持子查询,语法如下:
insert into 表名
查询语句;

eg:
insert into beauty(id,name,phone)
select 23,'刘亦菲'110;(会省略values

二、修改

(一)、修改单表的记录 ★

语法:
update 表名 
set 字段=,字段=值 
【where 筛选条件】;

(二)、修改多表的记录【补充】

语法:
update1 别名 
left|right|inner join2 别名 
on 连接条件 
set 字段=,字段=值 
【where 筛选条件】;

三、删除

(一)、方式一:使用delete

  1. 删除单表的记录★
  • 语法:

    delete from 表名 【where 筛选条件】【limit 条目数】
    
  1. 级联删除[补充]
  • 语法:

    delete 别名1,别名2 from1 别名 
    inner|left|right join2 别名 
    on 连接条件
     【where 筛选条件】
    

(二)、方式二:使用truncate

  • 语法:

    truncate table 表名
    

(三)、两种方式的区别【面试题】★

  1. truncate删除后,如果再插入,标识列从1开始
    delete删除后,如果再插入,标识列从断点开始
  2. delete可以添加筛选条件
    truncate不可以添加筛选条件
  3. truncate效率较高
  4. truncate没有返回值
    delete可以返回受影响的行数
  5. truncate不可以回滚
    delete可以回滚
原文地址:https://www.cnblogs.com/liuzhixian666/p/13829361.html