2 baidu 27823779 baidu_27823779 于 2015.06.06 14:12 提问

java 多线程 批量执行JDBC的 executeBatch会产生脏数据嘛

java多线程并发,每个线程中会生成多个sql语句,利用JDBC的executeBatch方法
对每个线程的产生的sql语句进行入库操作,这样会不会导致写入脏数据:
比如:A线程正在写入100条数据,B线程也正在写入100条数据,当执行JDBC的批量执行SQL的时候,会不会把B的数据复制到A的数据 中:
JDBC的 方法如下:

String sql="insert into xxx(id,ratio,date,status,close)"
+ "values(?,?,?,?,?)";
PreparedStatement pst=conn.prepareStatement(sql);
String code="";
for(Today ts:tslist){
pst.setString(1, ts.getxxx);
pst.setDouble(2, ts.getxxx);
pst.setInt(3, ts.getxxx);
pst.setInt(4, ts.getxxx);
pst.setInt(5, ts.getxxx );
pst.addBatch();
}
int arr[]=pst.executeBatch();

这种数据库的批量操作,在多线程下,是不是会产生脏数据,请大牛们解答一下:

1个回答

danielinbiti
danielinbiti   Ds   Rxr 2015.06.06 23:36

这数据库没关系,关键看你插入数据不同线程之间是否有重复。

danielinbiti
danielinbiti 回复baidu_27823779: 数据没有关联性,和脏数据没关系
2 年多之前 回复
baidu_27823779
baidu_27823779 数据不会有重复,每个线程执行的数据不会有重复的,但是这个操作是在每个线程内做的,但是jdbc的批量方法又不是线程安全的,所以我感觉数据会产生一下一些脏数据
2 年多之前 回复
Csdn user default icon
上传中...
上传图片
插入图片