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();
这种数据库的批量操作,在多线程下,是不是会产生脏数据,请大牛们解答一下: