Java中如何实现j并发更新数据库同一条数据
分情况来说:普通单应用并发、多应用或多台服务器并发
情况一:普通单应用并发
使用关键字synchronized就可实现。
情况二:多应用或多台服务器并发
因多个应用之间并非同一个jvm(应用)内,因此使用synchronized并不能满足需求。
具体处理方案包含以下几种:
1)数据库行级索,优点:简单粗暴;缺点:容易死锁&性能差,非数据库专业人士不建议使用。
2)写入请求分离到一个独立应用项目中,这个实现与“情况一”一致。优点:实现技术难度低;缺点:高并发性能相对不是特别高。
3)使用分布式事务管理,该方案是目前高并发处理的最优方案。关于分布式事务管理请参考《常用的分布式事务解决方案介绍有多少种?》《深入理解分布式事务,高并发下分布式事务的解决方案》
参考:https://zhidao.baidu.com/question/2139020837540241548.html
Java中如何实现j并发更新数据库同一条数据的更多相关文章
- 如何知道刚刚插入数据库那条数据的id
		
如何知道刚刚插入数据库那条数据的id 一.总结 一句话总结:这些常见功能各个框架里面都有,可以查看手册,thinkphp里面是$userId = Db::name('user')->getLas ...
 - innodb中一颗B+树能存储多少条数据
		
如图,为B+树组织数据的方式: 实际存储时当然不会每个节点只存3条数据. 以InnoDB引擎为例,简单计算一下一颗B+树可以存放多少行数据. B+树特点:只有叶子节点存储数据,而非叶子节点存放的是用来 ...
 - 如何理解Java中眼花缭乱的各种并发锁?
		
在互联网公司面试中,很多小伙伴都被问到过关于锁的问题. 今天,我给大家一次性把Java并发锁的全家桶彻底讲明白.包括互斥锁.读写锁.重入锁.公平锁.悲观锁.自旋锁.偏向锁等等等等.视频有点长,大家一定 ...
 - JAVA中怎么处理高并发的情况
		
一.背景综述 并发就是可以使用多个线程或进程,同时处理(就是并发)不同的操作. 高并发的时候就是有很多用户在访问,导致系统数据不正确.糗事数据的现象.对于一些大型网站,比如门户网站,在面对大量用户访问 ...
 - 谈论java中怎样处理高并发的问题
		
1 从最基础的地方做起,优化我们写的代码,降低必要的资源浪费. a.避免频繁的使用new对象.对于整个应用仅仅须要存在一个实例的类.我们能够使用单例模式. 对于String连接操作,使 ...
 - iOS中使用FMDB事务批量更新数据库
		
今天比较闲看到大家在群里讨论关于数据库操作的问题,其中谈到了"事务"这个词,坦白讲虽然作为计算机专业的学生,在上学的时候确实知道存储过程.触发器.事务等等这些名词的概念,但是由于毕 ...
 - 《java并发编程实战》读书笔记4--基础构建模块,java中的同步容器类&并发容器类&同步工具类,消费者模式
		
上一章说道委托是创建线程安全类的一个最有效策略,只需让现有的线程安全的类管理所有的状态即可.那么这章便说的是怎么利用java平台类库的并发基础构建模块呢? 5.1 同步容器类 包括Vector和Has ...
 - Code First Migrations更新数据库结构(数据迁移)
		
背景 code first起初当修改model后,要持久化至数据库中时,总要把原数据库给删除掉再创建 (DropCreateDatabaseIfModelChanges),此时就会产生一个问题,当我们 ...
 - 使用Code first 进行更新数据库结构(数据迁移)
		
CodeFirst 背景 code first起初当修改model后,要持久化至数据库中时,总要把原数据库给删除掉再创建(DropCreateDatabaseIfModelChanges),此时就会 ...
 
随机推荐
- 使用Quartz 2D擦除图片
			
Quartz 2D 是一个强大的二位图像绘制引擎,在开发中如果遇到需要高度自定义的控件,我们就可能需要用Core Graphics进行绘制. 这几天一同事开发一个聊天中的一个子模块,A 画一幅图,然后 ...
 - numpy用法小结
			
前言 个人感觉网上对numpy的总结感觉不够详尽细致,在这里我对numpy做个相对细致的小结吧,在数据分析与人工智能方面会有所涉及到的东西在这里都说说吧,也是对自己学习的一种小结! numpy用法的介 ...
 - ACCESS_ONCE
			
宏定义: #define ACCESS_ONCE(x) (*(volatile typeof(x) *)&(x)) 分解: typeof(x):取x的类型,如果x是int,那typeof(x) ...
 - springMVC正确使用GET POST PUT和DELETE方法,如何传递参数
			
1. 向服务器请求数据:GET 这是标准的http的GET最擅长的, 应该使用GET请求,但是在使用时候我们会需要传递一个或多个参数给服务器, 这些出参数可能是基本数据类型页可能是对象,get方法可以 ...
 - Java CAS机制详解
			
CAS目的: 在多线程中为了保持数据的准确性,避免多个线程同时操作某个变量,很多情况下利用关键字synchronized实现同步锁,使用synchronized关键字修可以使操作的线程排队等待运行,可 ...
 - npm 和bower之间的区别
			
(一) npm是node js的包管理器,用来下载安装node js的第三方工具包,也可以用来发布你自己开发的工具包.通过npm可以安装bower,命令如下: npm install -g bower ...
 - Android Studio设置字体和主题
			
步骤:File >> settings >> Appearance & Behavior >> Appearance >> ...
 - 【Flask】 网站的用户管理
			
网站用户管理 不知道为什么很多学习Flask的人都是从搭博客开始的(大概是因为那本书的案例是博客,同时对bootstrap支持良好,bootstrap又是twitter开发的吧..)既然是搭建博客,就 ...
 - SQL Quick Reference From W3Schools
			
SQL Statement Syntax AND / OR SELECT column_name(s)FROM table_nameWHERE conditionAND|OR condition AL ...
 - Eclipse+Pydev环境搭建
			
1,准备好Eclipse和JAVA,x64 2,安装JDK,配置JAVA环境变量,假设安装路径为 C:\Program Files\Java\jdk1.8.0_161 在系统变量中,新建CLASSPA ...