多线程并发访问数据库中不同记录时应该采用什么办法?
一、多线程并发访问数据库中不同记录时应该采用什么办法
关系型数据库基本已经解决你的问题了。数据库有行级锁。
注意以下都是一个事务内包含了多个线程并发访问时候的一些建议,多线程程序一般都是开在同一个事务点上,所以才有下面的一点建议。
但设计的程序的时候还是很有难度的。
一个事务内的多个线程,尽量别交叉执行,分两部分执行,部分1 读数据库 部分2 写数据库。
先读后写,如果业务允许的话。这样可以有效避免很多障碍,甚至很解决不了的坑。
(比如一个写线程还没提交,一个大的读线程恰巧导致写线程无法提交,等待读线程完成才会提交,会照成很长时间的锁等待,一堵塞,就很容易产生数据库假死。)
对于一个事务内的多个线程,有时候脏读是合理的情况下,一定要合理利用,这样可以避免无法分成读写两部分执行而产生等待的问题,比如可以提前在写队列里面提前commit,那么读的部分完全可以异步,首先要确认业务是否可行,要不就会出错数据,这地方是个钢丝绳。
也就是,题主不要认为多线程可以完全异步,那样成本和设计难度是几何上升的(关系型数据库几乎不太可能)。
异步和同步混用,可以考虑采用队列等数据结构来进行多线程控制顺序。
延伸阅读:
二、Power BI是什么
Power BI(power business intelligence)是软件服务、应用和连接器的集合,它们协同工作以将相关数据来源转换为连贯的视觉逼真的交互式见解。 无论用户的数据是简单的 Excel 电子表格,还是基于云和本地混合数据仓库的集合,Power BI 都可让用户轻松地连接到数据源,直观看到(或发现)重要内容,与任何所希望的人进行共享。
Power BI 简单且快速,能够从 Excel 电子表格或本地数据库创建快速见解。 同时 Power BI 也可进行丰富的建模和实时分析,及自定义开发。 因此它既是用户的个人报表和可视化工具,还可用作组项目、部门或整个企业背后的分析和决策引擎。
猜你喜欢LIKE
相关推荐HOT
更多>>什么是容器镜像仓库?
一、什么是容器镜像仓库容器镜像仓库是一种存储库(或存储库集合),可用来存储和访问容器镜像。容器镜像仓库可以为基于容器型应用开发提供支持...详情>>
2023-10-16 23:28:28什么是商业智能?
一、什么是商业智能商业智能 (BI) 是利用人员和技术的力量来收集和分析组织在其战略和日常决策过程中使用的数据的过程。二、商业智能解决方案的...详情>>
2023-10-16 22:11:30数据库、操作系统、编译原理是什么意思?
一、数据库、操作系统、编译原理是什么数据库(Database)是指用于存储和管理数据的系统。它是一个组织化的数据集合,可以通过结构化方式存储、...详情>>
2023-10-16 20:47:21Android系统开发做什么?
一、Android系统开发做什么1、设计Android开发设计可以创建界面和交互元素,使应用程序更加互动和吸引人。设计师需要考虑多方面因素,如设计原...详情>>
2023-10-16 16:58:30