专栏首页学习分享-实践为王解决数据库主键冲突的问题记录文档
原创

解决数据库主键冲突的问题记录文档

解决数据库主键冲突的问题记录文档

1、ORACLE

 然后修改一下开始于的字段即可。

2、MySql

select * from sequences;

查询队列的数据,修改Startwith的值

新增数据的基本语法为:

insert into + 表名 + [(字段列表)] + values (值列表);

在数据插入的时候,假设主键对应的值已经存在,则插入失败!这就是主键冲突。 当主键存在冲突(duplicate key)的时候,可以选择性的进行处理,即忽略、更新或者替换。

1. 忽略(推荐)

insert ignore into

遇主键冲突,保持原纪录,忽略新插入的记录。

mysql> select * from device ;
+-------+--------+-------------+
| devid | status | spec_char   |
+-------+--------+-------------+
|     1 | dead   | zhonghuaren | 
|     2 | dead   | zhong       | 
+-------+--------+-------------+
2 rows in set (0.00 sec)

mysql> insert into device values (1,'alive','yangting');
ERROR 1062 (23000): Duplicate entry '1' for key 'PRIMARY'

mysql> insert ignore  into device values (1,'alive','yangting');
Query OK, 0 rows affected (0.00 sec)

mysql> select * from device ;
+-------+--------+-------------+
| devid | status | spec_char   |
+-------+--------+-------------+
|     1 | dead   | zhonghuaren | 
|     2 | dead   | zhong       | 
+-------+--------+-------------+
2 rows in set (0.00 sec)

可见 insert ignore into当遇到主键冲突时,不更改原纪录,也不报错

2.替换

replace into

遇主键冲突,替换原纪录,即先删除原纪录,后insert新纪录

mysql> replace  into device values (1,'alive','yangting');
Query OK, 2 rows affected (0.00 sec)

mysql> select * from device ;
+-------+--------+-----------+
| devid | status | spec_char |
+-------+--------+-----------+
|     1 | alive  | yangting  | 
|     2 | dead   | zhong     | 
+-------+--------+-----------+
2 rows in set (0.00 sec)

3. 更新

insert into ... ON DUPLICATE KEY UPDATE

其实这个是原本需要执行3条SQL语句(SELECT,INSERT,UPDATE),缩减为1条语句即可完成。 即

IF (SELECT * FROM where 存在) {
    UPDATE  SET  WHERE ;
} else {
    INSERT INTO;
}

如:

mysql> insert into device values (1,'readonly','yang') ON DUPLICATE KEY UPDATE status ='drain';
Query OK, 2 rows affected (0.00 sec)

上面语句伪代码表示即为

if (select * from device where devid=1) { 
    update device set status ='drain' where devid=1 
} else {
    insert into device values (1,'readonly','yang')
}

很明显,devid=1 是有的,这样就执行update操作

mysql> select * from device ;
+-------+--------+-----------+
| devid | status | spec_char |
+-------+--------+-----------+
|     1 | drain  | yangting  | 
|     2 | dead   | zhong     | 
+-------+--------+-----------+
2 rows in set (0.00 sec)

测试表:

CREATE TABLE `device` (
`devid` mediumint(8) unsigned NOT NULL AUTO_INCREMENT,
`status` enum('alive','dead','down','readonly','drain') DEFAULT NULL,
`spec_char` varchar(11) DEFAULT '0',
PRIMARY KEY (`devid`)
) ENGINE=InnoDB

项目采用UUID作为主键的冲突解决

在项目中,比如插入一条user信息,主键采用随机UUID的冲突解决。 可以考虑采用第一种忽略的方式,当主键冲突,数据库插入语句的返回值为0,然后我们判断数据库插入的返回值,如果为0,则重新生成主键,再次进行插入,直到完成插入操作!

原创声明,本文系作者授权云+社区发表,未经许可,不得转载。

如有侵权,请联系 yunjia_community@tencent.com 删除。

关注作者,阅读全部精彩内容

我来说两句

0 条评论
登录 后参与评论

相关文章

  • mybatis和mybatisPlus中解决实体类字段与数据库关键字冲突问题

      由于数据库表字段名称设计不合理,导致与MySQL数据库关键字或者预留关键字一致,在这种情况下,将会导致数据插入不成功,这里主要针对Mybatis和Mybat...

    Java架构师必看
  • DataSet导入三个坑

    外键是一个常见的保证数据库内容完整性的一种方式。当然现在出于性能考虑,在互联网企业中比较少甚至禁止使用外键。在DBRider中,提供了以下的与外键相关的功能 1...

    Antony
  • 使用dbms_rectifier_diff解决高级复制中的数据冲突问题

    « Oracle基于时间点的恢复 | Blog首页 | 关于Oracle的冲突解决机制的研究 »

    数据和云01
  • Git合并分支时,代码冲突的解决办法

    https://blog.csdn.net/su1573/article/details/91990437

    chenchenchen
  • 一文理解MySQL的锁机制与死锁排查

    MySQL的并发控制是在数据安全性和并发处理能力之间的权衡,通过不同的锁策略来决定对系统开销和性能的影响。

    全菜工程师小辉
  • elasticsearch-快速入门

    正排索引是从文档到关键字的映射(已知文档求关键字),倒排索引是从关键字到文档的映射(已知关键字求文档)。

    黎明大大
  • Web-第二十七天 SVN使用【悟空教程】

    为保障团队开发过程中人员沟通各方面成本的降低,必须使用一种有效的方式减少沟通环节,提高开发效率,对资源的共享进行管理。

    Java帮帮
  • SVN学习笔记.

    一、什么是SVN?        Subversion(SVN) 是一个开源的版本控制系統, 也就是说 Subversion 管理着随时间改变的数据。 这些数据...

    JMCui
  • 漫谈死锁

    一 前言 死锁是每个MySQL DBA 都会遇到的技术问题,本文是自己针对死锁学习的一个总结,了解死锁是什么,MySQL如何检测死锁,处理死锁,死锁的案例,...

    用户1278550
  • 零停机迁移 Postgres的正确方式

    在这篇博文中,我们会介绍如何在零停机时间的前提下,使用 Bucardo 将 Postgres 数据库迁移到一个新实例上。我们将介绍如何避免常见的陷阱,比如数据丢...

    深度学习与Python
  • 一条payload发生的事情(来自对报错注入的思考)

    最近在重新整理复现MYSQL注入天书,遇到了一条很有意思的报错注入的payload:

    Elapse
  • 数据库突然宕机无法open的问题及解决

    测试的数据库有一天突然宕机,然后无法正常open了,这个问题虽然过去了一段时间,也在这儿总结一把。 从alert日志中的信息如下。 Fri Jan 10 16...

    jeanron100
  • Sync Framework 2.0

    Sync Framework 是一个功能完善的同步平台,实现了应用程序、服务和设备的协作和脱机访问。Sync Framework 提供了一些可支持在脱机状态下漫...

    张善友
  • MySQL的死锁系列- 锁的类型以及加锁原理

    疫情期间在家工作时,同事使用了 insert into on duplicate key update 语句进行插入去重,但是在测试过程中发生了死锁现象:

    程序员历小冰
  • MySQL的死锁系列- 锁的类型以及加锁原理

    疫情期间在家工作时,同事使用了 insert into on duplicate key update 语句进行插入去重,但是在测试过程中发现了死锁现象:

    程序员历小冰
  • 怎样将数据从Oracle迁移到TiDB

    Best Practice for Data migration from Oracleto Tidb

    杨漆
  • MySQL双主一致性架构优化 | 架构师之路

    一、双主保证高可用 MySQL数据库集群常使用一主多从,主从同步,读写分离的方式来扩充数据库的读性能,保证读库的高可用,但此时写库仍然是单点。 在一个MySQL...

    架构师之路
  • Mysql的索引结构为什么要用B+数

    在MySQL中,无论是Innodb还是MyIsam,都使用了B+树作索引结构(这里不考虑hash等其他索引)。本文将从最普通的二叉查找树开始,逐步说明各种树解决...

    程序员白楠楠
  • MySQL中锁机制超详细解析

    锁是计算机协调多个进程或纯线程并发访问某一资源的机制。在数据库中,除传统的计算资源(CPU、RAM、I/O)的争用以外,数据也是一种供许多用户共享的资源。如何保...

    博文视点Broadview

扫码关注云+社区

领取腾讯云代金券