ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

MySQL主键唯一键重复插入解决方法

2021-07-02 11:52:58  阅读:124  来源: 互联网

标签:name yoona age id 插入 stuInfo MySQL 主键


我们插入数据的时候,有可能碰到重复数据插入的问题,但是这些数据又是不被允许有重复值:

  1. CREATE TABLE stuInfo (
  2. id INT NOT NULL COMMENT '序号',
  3. name VARCHAR(20) NOT NULL DEFAULT '' COMMENT '姓名',
  4. age INT NOT NULL DEFAULT 0 COMMENT '年龄',
  5. PRIMARY KEY (id),
  6. UNIQUE KEY uniq_name(name)
  7. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='学生表';

 

  1. mysql> INSERT INTO stuInfo (id,name,age) VALUES (1,'yoona',20),(1,'xiaosi',25),(2,'aa',24);
  2. ERROR 1062 (23000): Duplicate entry '1' for key 'PRIMARY'

解决方案:

1. IGNORE

使用ignore当插入的值遇到主键(PRIMARY KEY)或者唯一键(UNIQUE KEY)重复时自动忽略重复的记录行,不影响后面的记录行的插入。

  1. INSERT IGNORE INTO stuInfo (name,birthday,is_deleted) VALUES ('yoona','1990-01-05',0),('aa','1990-01-16',0),('bb','1990-01-17',0);

运行结果:

  1. mysql> INSERT IGNORE INTO stuInfo (id,name,age) VALUES (1,'yoona',20),(1,'xiaosi',25),(2,'aa',24);
  2. Query OK, 2 rows affected (0.02 sec)
  3. Records: 3 Duplicates: 1 Warnings: 0
  4.  
  5. mysql> select * from stuInfo;
  6. +----+-------+-----+
  7. | id | name | age |
  8. +----+-------+-----+
  9. | 1 | yoona | 20 |
  10. | 2 | aa | 24 |
  11. +----+-------+-----+
  12. 2 rows in set (0.00 sec)

我们可以从运行结果中看出,只有两行受到影响,意思即(1,'yoona',20)数据插入,(1,'xiaosi',25)重复数据自动被忽略,(2,'aa',24)不重复数据继续插入,不会受到重复数据的影响;

2. REPLACE

使用replace当插入的记录遇到主键或者唯一键重复时先删除表中重复的记录行再插入。

  1. mysql> REPLACE INTO stuInfo (name,birthday,is_deleted) VALUES ('yoona','1990-01-15',0),('yoona','1990-02-16',0),('aa','1990-01-13',0);
  2. Query OK, 4 rows affected (0.02 sec)
  3. Records: 3  Duplicates: 1  Warnings: 0

运行结果:

  1. mysql> select * from stuInfo;                                                   +----+-------+------------+------------+
  2. | id | name  | birthday   | is_deleted |
  3. +----+-------+------------+------------+
  4. | 21 | yoona | 1990-02-16 |          0 |
  5. | 22 | aa    | 1990-01-13 |          0 |
  6. +----+-------+------------+------------+
  7. 2 rows in set (0.00 sec)

从输出的信息可以看到是4行受影响,说明它是先插入了('yoona','1990-01-15',0)然后又删除了('yoona','1990-01-15',0)。

3. ON DUPLICATE KEY UPDATE

当插入的记录遇到主键或者唯一键重复时,会执行后面定义的UPDATE操作。相当于先执行Insert 操作,再根据主键或者唯一键执行update操作。

  1. DROP TABLE  IF EXISTS stuInfo;
  2. CREATE TABLE stuInfo (
  3.  id INT NOT NULL COMMENT '序号',
  4.  name VARCHAR(20) NOT NULL DEFAULT '' COMMENT '姓名',
  5.  age INT NOT NULL DEFAULT 0 COMMENT '年龄',
  6.  PRIMARY KEY (id),
  7.  UNIQUE KEY uniq_name(name)
  8. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='学生表';

 

在ON DUPLICATE KEY UPDATE后VALUES解释:

VAULES(age)指的是待插入的记录的值

age指得是表的自身值,已插入值。

(1)第一种情形:

  1. #VALUES(age) 待插入值 25
  2. INSERT INTO stuInfo (id,name,age) VALUES (1,'yoona',20),(1,'xiaosi',25) ON DUPLICATE KEY UPDATE age = VALUES(age) + 1;

相当于:

  1. INSERT INTO stuInfo (id,name,age) VALUES (1,'yoona',20);
  2. UPDATE stuInfo
  3. SET age = VALUES(age) + 1
  4. WHERE id = 1;

运行结果:

  1. mysql> INSERT INTO stuInfo (id,name,age) VALUES (1,'yoona',20),(1,'xiaosi',25) ON DUPLICATE KEY UPDATE age = VALUES(age) + 1;
  2. Query OK, 3 rows affected (0.01 sec)
  3. Records: 2 Duplicates: 1 Warnings: 0
  4.  
  5. mysql> select * from stuInfo;
  6. +----+-------+-----+
  7. | id | name | age |
  8. +----+-------+-----+
  9. | 1 | yoona | 26 |
  10. +----+-------+-----+
  11. 1 row in set (0.00 sec)

 

(2)第二种情形:

  1. #age 已插入值 20
  2. INSERT INTO stuInfo (id,name,age) VALUES (1,'yoona',20),(1,'xiaosi',25) ON DUPLICATE KEY UPDATE age = age + 1;

相当于:

  1. INSERT INTO stuInfo (id,name,age) VALUES (1,'yoona',20);
  2. UPDATE stuInfo
  3. SET age = age + 1
  4. WHERE id = 1;

运行结果:

  1. mysql> INSERT INTO stuInfo (id,name,age) VALUES (1,'yoona',20),(1,'xiaosi',25) ON DUPLICATE KEY UPDATE age = age + 1;
  2. Query OK, 3 rows affected (0.02 sec)
  3. Records: 2 Duplicates: 1 Warnings: 0
  4.  
  5. mysql> select * from stuInfo;
  6. +----+-------+-----+
  7. | id | name | age |
  8. +----+-------+-----+
  9. | 1 | yoona | 21 |
  10. +----+-------+-----+
  11. 1 row in set (0.00 sec)

 

如果遇到重复插入的数据的情形,ON DUPLICATE KEY UPDATE用来对已插入的数据进行修改,可以使用获取重复已插入数据(直接使用字段名称),也可以获取重复待插入数据(values(字段名称))。我们不会对重复待插入数据进行插入操作。

重复已插入数据:上例中的(1,'yoona',20)

重复待插入数据:上例中的(1,'yoona',25)

标签:name,yoona,age,id,插入,stuInfo,MySQL,主键
来源: https://blog.51cto.com/u_7692005/2968721

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有