mysql16-高级操作之新增、更新、删除

新增数据

多数据插入

只要写一次insert指令,但是可以直接插入多条记录
基本语法:insert into 表名[(字段列表)]values (值列表),(值列表)…;

主键冲突

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

主键冲突的解决方案

  1. 主键冲突更新
    类似插入数据语法,如果插入的过程中主键冲突,那么采用更新方法。
    insert into 表名[(字段列表)]values (值列表) on duplicate key update 字段=新值
  2. 主键冲突替换
    当主键冲突之后,干掉原来的数据,重新插入进去
    replace into [(字段列表)]values (值列表);

    蠕虫复制

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

    基本语法
    insert into 表名 【(字段列表)】select */字段表名 from 表名

注意:

  1. 蠕虫复制的确通常是重复数据,没有太大业务意义:可以在短期内快速增加表的数据量,从而可以测试表的压力,还可以通过大量数据来测试表的效率(索引)
  2. 蠕虫复制虽好,但是要注意主键冲突。
  3. 配合 复制已有表机构语句 就可以完成表的复制
    复制已有表机构语句:从已经存在 表赋值一份(只复制结构:如果表中有数据不复制)create table 新表名 like 表名 //只要使用数据库.表名,就可以在任意数据库下访问其他数据库表

更新数据

  1. 在更新数据的时候,特别要注意:通常一定是跟随条件更新的
    update 表名 set 字段名 =新值 where 判断条件

如果没有条件,是全表更新数据。但是可以使用limit来显示更新的数量;
update 表名 set 字段名=新值【where 判断条件】limit 数量

例如:改变4个a变成e
update my_simple set name=’e’ where name=’a’ limit 4

删除数据

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

delete删除数据的时候无法重置auto_increment

mysql有一个能够重置表选项中的自增长的语法
truncate 表名;等价于 ->drop ->create