1 简介

数据库操作语言
插入:insert
修改:update
删除:delete

2. 插入语句

2.1 语法

insert into 表名 (列名,,…) values(值1,…)

2.2 案例

1)插入的值的类型要与列的类型一致或兼容

  1. mysql> insert into beauty(id,name,sex,borndate,phone,photo,boyfriend_id) values(13,'dahu','女','2020-01-01','188220804742',NULL,2);
  2. Query OK, 1 row affected (0.00 sec)

2)配合查询子句使用

  1. mysql> insert into beauty (name,phone) select boyName,'110' from boys;
  2. Query OK, 4 rows affected (0.00 sec)

3.修改语句

3.1 语法

1)修改单表的记录
update 表名
set 列=新值,列=新值,…
where 筛选条件

2)修改多表的记录
sql92:
update 表1 别名, 表2,别名
set 列=值,…
where 连接条件
and 筛选条件;

sql99:
update 表1 别名
inner | left | right join 表2 别名
on 连接条件
set 列=值,…
where 筛选条件

3.2 案例

1)修改单表的记录

  1. mysql> update beauty set phone='123' where name like '周%';
  2. Query OK, 2 rows affected (0.00 sec)

2)修改张无忌女朋友的手机号为114

  1. mysql> update boys bo inner join beauty b on bo.id = b.boyfriend_id set b.phone='114' where bo.boyName='张无忌';
  2. Query OK, 3 rows affected (0.00 sec)
  3. Rows matched: 3 Changed: 3 Warnings: 0

4.删除语句

4.1 语法

方式1: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 筛选条件

方式2:truncate
语法:
truncate table 表名

4.2 案例

1)删除手机号为9结尾的行

  1. mysql> delete from beauty where phone like '%9';
  2. Query OK, 3 rows affected (0.00 sec)

2)删除张无忌女朋友的信息

  1. mysql> delete b from beauty b right join boys bo on bo.id = b.boyfriend_id where bo.id = 1;
  2. Query OK, 3 rows affected (0.00 sec)

4.3 delete pk truncate

1.delete 可以加where条件,truncate不能加
2.truncate删除,效率高一点
3.删除的表中如果有自增长列,用delete删除后在插入数据,自增长列的值从断点开始
而truncate删除后,再插入数据,自增长列的值从1开始
4.truncate 删除后没有返回值,delete删除后有返回值
5.truncate删除不能回滚,delete删除可以回滚