多个线程访问数据库问题(多线程并发访问数据库)

多个线程访问数据库问题(多线程并发访问数据库),第1张

oracle数据库中,每个客户端进程(userprocess)都会有一个服务端进程()与之对应连接,称为一个session。

每个都会有独立的PGA,所有共享SGA资源。

sql多用户访问数据库其实就是事务并发,会引起如下问题:

1、脏读:一个事务读取到了另外一个事务没有提交的数据

事务1:更新一条数据

事务2:读取事务1更新的记录

事务1:调用commit进行提交

此时事务2读取到的数据是保存在数据库内存中的数据,称为脏读。

读到的数据为脏数据

详细解释:

脏读就是指:当一个事务正在访问数据,并且对数据进行了修改,而这种修改还没有提交到数据库中,这时,

另外一个事务也访问这个数据,然后使用了这个数据。因为这个数据是还没有提交的数据,那么另外一个

事务读到的这个数据是脏数据,依据脏数据所做的 *** 作可能是不正确的。

2、不可重复读:在同一事务中,两次读取同一数据,得到内容不同

事务1:查询一条记录

事务2:更新事务1查询的记录

事务2:调用commit进行提交

事务1:再次查询上次的记录

此时事务1对同一数据查询了两次,可得到的内容不同,称为不可重复读。

3、幻读:同一事务中,用同样的 *** 作读取两次,得到的记录数不相同

事务1:查询表中所有记录

事务2:插入一条记录

事务2:调用commit进行提交

事务1:再次查询表中所有记录

此时事务1两次查询到的记录是不一样的,称为幻读

我觉得1万的数据并发量并不大,想oracle数据库,mysql承载这些并发是没有问题的

我觉得,主要的问题在于你GPS是一直在修改的,因为车辆在不断的行驶,这样的话,可能会影响数据库的性能

我觉得,你可以用一个内存行的数据库,比如,redis,用这个来存放GPS信息,redis是基于内存的,读写要比关系数据库速度快(忽略网络因素),你可能要问GPS入库怎么弄,可以做一个定时任务,每隔多少时间来将redis的数据写入到数据库中,当然,redis也支持一些算法,比如LRU,来设置何时将数据同步到数据库

以上就是关于多个线程访问数据库问题(多线程并发访问数据库)全部的内容,包括:多个线程访问数据库问题(多线程并发访问数据库)、使用数据库连接池,怎么解决多个用户并发的向数据库中插入数据、java多用户同时访问和数据库进行交互,如何能够高并发等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/9749452.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-01
下一篇2023-05-01

发表评论

登录后才能评论

评论列表(0条)

    保存