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

猜你喜欢LIKE
相关推荐HOT
更多>>
RESTful API的命名有什么讲究?
一、RESTful API的命名有什么讲究和目录没关系,通常是框架路由接管的 request uri解析出来的(v1、v2有可能是实际的目录)restful规范/资源名/...详情>>
2023-10-18 23:56:05
文件系统和数据库是由于什么原因才选择B树或B+树建立?
一、文件系统和数据库是由于什么原因才选择B树或B+树建立索引的索引的目标是要找到数据所在的物理位置,因此用树去实现搜索数据所在物理位置,...详情>>
2023-10-18 22:55:19
mysql如果单表数据量过千万怎么办?
一、mysql如果单表数据量过千万怎么办方案概述方案一:优化现有mysql数据库。优点:不影响现有业务,源程序不需要修改代码,成本最低。缺点:有...详情>>
2023-10-18 22:33:40
数据库表名、字段名用中文有什么问题?
一、数据库表名、字段名用中文的问题1、兼容性问题某些数据库管理系统(DBMS)可能不支持使用中文作为表名和字段名,或者对于中文的支持有限。...详情>>
2023-10-18 21:09:43热门推荐
RESTful API的命名有什么讲究?
沸KEGG 怎么用?
热文件系统和数据库是由于什么原因才选择B树或B+树建立?
热mysql如果单表数据量过千万怎么办?
新什么情况下需要使用分布式数据库?
为什么Cassandra的写速度比MySQL快?
数据库表名、字段名用中文有什么问题?
数据库文件存放在NAS中,会有什么问题吗?
多线程并发访问数据库中不同记录时应该采用什么办法?
为什么mysql要额外加入一个utf8mb4数据类型,而不是原地升级utf8?
PolarDB-X与PolarDB的关键区别是什么?
Mysql、SQLite、Mongo的区别?
为什么用Go语言做Web应用开发框架?
什么是i.MXRT11xx上的串行NOR Flash双程序可交替启动?
技术干货






