多线程数据库操作问题,请大家给予解读,谢谢!

有这样一个特殊情况:
有两个线程,他们之间是竞争关系,没有做同步,

 线程A:读取数据库中ID从1到10000的记录(假使需要10s完成整个读取)
存储区:负责存放线程A读取的数据库结果集
 线程B:读取存储区的数据库并打印

在这样的场景下,是否会出现,当线程A获得CPU时间后开始读取数据库,数据库的结果集正在网络上传输,

此时,线程B抢夺了线程A的运行权开始运行,请问,此时正在网络上传输的数据库的结果集怎么办?是被抛弃

还是被放到一个地方,等线程A恢复运行后再取出进行处理?


希望大家讨论一下这个过程,谢谢!

2个回答

A被咔嚓,传输的继续传输,
B开始读取,读到哪算哪。
都传输完了,B就能都读到,传输不完,B就只能读到存储区里面的已有数据。

单例,线程同步,加锁,等等方法都能解决。

看你的业务要求了,如果你的业务要求是只要读取开始了,那么就要在B中表现,那最好做个同步,事务级别上的同步

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!