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

新增数据

先创建一张表

 

多数据插入

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

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

主键冲突

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

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

 

主键冲突的解决方案:

插入数据 :

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

1、 主键冲突更新:

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

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

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

2、 主键冲突替换:

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

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

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

 

蠕虫复制

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

基本语法:

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

注意:

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

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

  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我才是真的封不觉

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值