1 简介
数据库操作语言
插入:insert
修改:update
删除:delete
2. 插入语句
2.1 语法
insert into 表名 (列名,,…) values(值1,…)
2.2 案例
1)插入的值的类型要与列的类型一致或兼容
mysql> insert into beauty(id,name,sex,borndate,phone,photo,boyfriend_id) values(13,'dahu','女','2020-01-01','188220804742',NULL,2);Query OK, 1 row affected (0.00 sec)
2)配合查询子句使用
mysql> insert into beauty (name,phone) select boyName,'110' from boys;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)修改单表的记录
mysql> update beauty set phone='123' where name like '周%';Query OK, 2 rows affected (0.00 sec)
2)修改张无忌女朋友的手机号为114
mysql> update boys bo inner join beauty b on bo.id = b.boyfriend_id set b.phone='114' where bo.boyName='张无忌';Query OK, 3 rows affected (0.00 sec)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结尾的行
mysql> delete from beauty where phone like '%9';Query OK, 3 rows affected (0.00 sec)
2)删除张无忌女朋友的信息
mysql> delete b from beauty b right join boys bo on bo.id = b.boyfriend_id where bo.id = 1;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删除可以回滚
