SQL高级操作之一——新增数据(主键冲突更新,主键冲突替换,蠕虫复制)

新增数据

先创建一张表

SQL高级操作之一——新增数据(主键冲突更新,主键冲突替换,蠕虫复制)_第1张图片

 

多数据插入

只要写一次insert指令,但是可以直接插入多条记录

基本语法:insert into 表名 [(字段列表)] values(值列表), (值列表)…;

SQL高级操作之一——新增数据(主键冲突更新,主键冲突替换,蠕虫复制)_第2张图片

主键冲突

主键冲突:在有的表中,使用的是业务主键(字段有业务含义),但是往往在进行数据插入的时候,又不确定数据表中是否已经存在对应的主键。

先创建一张带业务主键的表

 

SQL高级操作之一——新增数据(主键冲突更新,主键冲突替换,蠕虫复制)_第3张图片

主键冲突的解决方案:

插入数据 :

SQL高级操作之一——新增数据(主键冲突更新,主键冲突替换,蠕虫复制)_第4张图片

当我们知道主键有哪些值的时候这样插入当然没问题,但是举个例子,想一想:比如我是一个学校录入学生信息的老师,录入张三信息的时候,学号录的张三的学号004,其它年龄,姓名等信息却录的李四的,此时我拿着张三的信息对比李四的修改是不是过于麻烦了,这时候就可以应用下面的主键冲突替换(容易点)或者主键冲突更新,我再次录入信息,学号为004,信息录张三,当主键相同时,会把原来的错误信息更新为新的

1、 主键冲突更新:

类似插入数据语法,如果插入的过程中主键冲突,那么采用更新方法。(记住update后面不要惯性的加了set)

Insert into 表名 [(字段列表)] values(值列表) on duplicate key update 字段 = 新值,字段=新值...;

如下当我不确定插入的数据是否业务主键重复,但确定插入数据无误时可以使用如下主键冲突更新

SQL高级操作之一——新增数据(主键冲突更新,主键冲突替换,蠕虫复制)_第5张图片

2、 主键冲突替换:

当主键冲突之后,干掉原来的数据,重新插入进去。

Replace into [(字段列表)] values(值列表);

把主键为003的其它字段替换掉:

SQL高级操作之一——新增数据(主键冲突更新,主键冲突替换,蠕虫复制)_第6张图片

 

蠕虫复制

蠕虫复制:一分为二,成倍的增加。从已有的数据中获取数据,并且将获取到的数据插入到数据表中。

基本语法:

Insert into 表名 [(字段列表)] select */字段列表 from 表;

SQL高级操作之一——新增数据(主键冲突更新,主键冲突替换,蠕虫复制)_第7张图片

注意:

1、 蠕虫复制的确通常是重复数据,没有太大业务意义:可以在短期内快速增加表的数据量,从而可以测试表的压力,还可以通过大量数据来测试表的效率(索引)

2、 蠕虫复制虽好,但是要注意主键冲突。

你可能感兴趣的:(mysql轻松学)