03-01-高级数据操作(新增 更新 删除 数据)

高级数据操作

新增数据

多数据插入

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

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

insert into my_teacher values('张三',10),('李四',15),('王五',20);

在这里插入图片描述

主键冲突

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

在这里插入图片描述

主键冲突解决方案:

  1. 主键冲突更新:

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

    在这里插入图片描述

    弊端

    如果字段多sql会特别长

  2. 主键冲突替换:

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

    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;

在这里插入图片描述

注意

  1. 蠕虫复制通常是重复数据,没有太大业务意义,但是它可以在短期内快速增加表的数据量,从而可以测试表的压力,还可以通过大量数据还测试表的效率(索引)。
  2. 蠕虫复制虽好,但是要注意主键冲突。

更新数据

  1. 在更新数据的时候,特别要注意:通常一定是跟随条件进行更新

    update 表名 set 字段名=新值 where 判断条件;

  2. 如果没有条件,是全表更新数据。但是可以使用limit来显示更新的数量

    update 表名 set 字段名=新值 [where 判断条件] limit 数量;

    需求

    改变my_simple表中4a变成e

    update my_simple set name='e' where name='a' limit 4;
    

    在这里插入图片描述

删除操作

  1. 删除数据时,尽量不要全部删除,应该使用where进行判定
  2. 删除数据时可以使用limit来限制要删除的具体数量

delete在删除数据的时候无法重制auto_increment
在这里插入图片描述

MySQL有一个能够重制表选项中的自动增长的语法

truncate 表名; 相当于删除了表 然后又创建了表

在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值