IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> 主键冲突和数据库隔离级别有关? -> 正文阅读

[大数据]主键冲突和数据库隔离级别有关?

数据库隔离级别

事务隔离级别脏读不可重复读幻读
读未提交(read-uncommitted)
读提交(read-committed)
可重复读(repeatable-read)
串行化(serializable)

假设:
A表,trans_date和pid为联合索引主键,B表pid为主键
目前并发情况下,需要将一行数据(主键相同)插入A表。当第一个事务插入成功后,后续事务不在插入,直接拿来用。
(别问为啥不在外面插入好,再并发。这是业务场景需要;
为什么不update锁,因为insert语句无记录锁不住)

代码逻辑为:
当线程1进来时,开启事务1,查询A是否已经存在trans_date和pid数据,存在则直接用,不存在则根据业务逻辑insert一条。
当线程2进来时,开启事务2,查询A是否已经存在trans_date和pid数据,存在则直接用,不存在则根据业务逻辑insert一条。
这个时候,按照正常想法来说,事务1提交后,事务2主键冲突插入报错。

但是如果sql这么写呢

insert into A  (
   trans_date,
   pid,
   reserve1,
   reserve2
   )
   select
   '20211212',
   '1',
   ' ',
   ' '
   from B where pid='1' and 
   not exists(select 1 from A where trans_date='20211212' 
   and pid='1')

加了not exists的判断呢,还会报错吗?

事实如下:
隔离级别为’read-committed’不可重复读时,开启两个事务,都执行插入语句(第一个插入后,第二个执行插入语句会等待),然后第一个事务提交,第二个事务随之报错。

事务隔离级别为 可重复读REPEATABLE-READ时,开启两个事务,都执行插入语句(第一个插入后,第二个执行插入语句会等待),然后第一个事务提交,第二个事务不报错,执行结果影响行数为0。


具体为啥我也不知道。谁能解释一下告诉我。

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2021-12-10 11:07:42  更:2021-12-10 11:09:58 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/17 7:55:38-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码