全国旗舰校区

不同学习城市 同样授课品质

北京

深圳

上海

广州

郑州

大连

武汉

成都

西安

杭州

青岛

重庆

长沙

哈尔滨

南京

太原

沈阳

合肥

贵阳

济南

下一个校区
就在你家门口
+
当前位置:首页  >  技术干货  >  详情

多线程并发访问数据库中不同记录时应该采用什么办法?

来源:千锋教育
发布人:xqq
2023-10-18

推荐

在线提问>>

一、多线程并发访问数据库中不同记录时应该采用什么办法

关系型数据库基本已经解决你的问题了。数据库有行级锁。

注意以下都是一个事务内包含了多个线程并发访问时候的一些建议,多线程程序一般都是开在同一个事务点上,所以才有下面的一点建议。

但设计的程序的时候还是很有难度的。

一个事务内的多个线程,尽量别交叉执行,分两部分执行,部分1 读数据库 部分2 写数据库。

先读后写,如果业务允许的话。这样可以有效避免很多障碍,甚至很解决不了的坑。

(比如一个写线程还没提交,一个大的读线程恰巧导致写线程无法提交,等待读线程完成才会提交,会照成很长时间的锁等待,一堵塞,就很容易产生数据库假死。)

对于一个事务内的多个线程,有时候脏读是合理的情况下,一定要合理利用,这样可以避免无法分成读写两部分执行而产生等待的问题,比如可以提前在写队列里面提前commit,那么读的部分完全可以异步,首先要确认业务是否可行,要不就会出错数据,这地方是个钢丝绳。

也就是,题主不要认为多线程可以完全异步,那样成本和设计难度是几何上升的(关系型数据库几乎不太可能)。

异步和同步混用,可以考虑采用队列等数据结构来进行多线程控制顺序。

延伸阅读:

二、Power BI是什么

Power BI(power business intelligence)是软件服务、应用和连接器的集合,它们协同工作以将相关数据来源转换为连贯的视觉逼真的交互式见解。 无论用户的数据是简单的 Excel 电子表格,还是基于云和本地混合数据仓库的集合,Power BI 都可让用户轻松地连接到数据源,直观看到(或发现)重要内容,与任何所希望的人进行共享。

Power BI 简单且快速,能够从 Excel 电子表格或本地数据库创建快速见解。 同时 Power BI 也可进行丰富的建模和实时分析,及自定义开发。 因此它既是用户的个人报表和可视化工具,还可用作组项目、部门或整个企业背后的分析和决策引擎。

相关文章

RESTful API的命名有什么讲究?

KEGG 怎么用?

文件系统和数据库是由于什么原因才选择B树或B+树建立?

mysql如果单表数据量过千万怎么办?

什么情况下需要使用分布式数据库?

开班信息 更多>>

课程名称
全部学科
咨询

HTML5大前端

Java分布式开发

Python数据分析

Linux运维+云计算

全栈软件测试

大数据+数据智能

智能物联网+嵌入式

网络安全

全链路UI/UE设计

Unity游戏开发

新媒体短视频直播电商

影视剪辑包装

游戏原画

    在线咨询 免费试学 教程领取