03-01-高级数据操作(新增 更新 删除 数据)
高级数据操作
新增数据
多数据插入
只要写一次insert
指令,可以直接插入多条记录
基本语法:
insert into 表名 [(字段列表)] values(值列表),(值列表)...;
insert into my_teacher values('张三',10),('李四',15),('王五',20);
主键冲突
在有的表中使用的是业务主键(字段有业务含义),但是往往在进行插入数据的时候,又不确定数据表中是否已经存在对应的主键
主键冲突解决方案:
-
主键冲突更新:
insert into 表名 [(字段列表)] values (值列表) on duplicate key update 字段=新值;
弊端
如果字段多
sql
会特别长 -
主键冲突替换:
当主键冲突后,干掉原来的数据,重新插入进去
replace into
弊端
replace
效率很低,它是先看是否有冲突,有冲突的话干掉原来的数据
蠕虫复制
蠕虫复制:一分为二,成倍的增加。从已有的数据中获取数据并且将获取到的数据插入到数据表中。
基本语法:
insert into 表名 [(字段列表)] select */字段列表 from 表;
create table my_simple(
name char(1) not null
)charset=utf8;
insert into my_simple values('a'),('b'),('c'),('d');
-- 蠕虫复制
insert into my_simple (name) select name from my_simple;
注意
- 蠕虫复制通常是重复数据,没有太大业务意义,但是它可以在短期内快速增加表的数据量,从而可以测试表的压力,还可以通过大量数据还测试表的效率(索引)。
- 蠕虫复制虽好,但是要注意主键冲突。
更新数据
-
在更新数据的时候,特别要注意:通常一定是跟随条件进行更新
update 表名 set 字段名=新值 where 判断条件;
-
如果没有条件,是全表更新数据。但是可以使用
limit
来显示更新的数量update 表名 set 字段名=新值 [where 判断条件] limit 数量;
需求
改变
my_simple
表中4
个a
变成e
update my_simple set name='e' where name='a' limit 4;
删除操作
- 删除数据时,尽量不要全部删除,应该使用
where
进行判定 - 删除数据时可以使用
limit
来限制要删除的具体数量
delete
在删除数据的时候无法重制auto_increment
MySQL
有一个能够重制表选项中的自动增长的语法
truncate 表名;
相当于删除了表 然后又创建了表