草庐IT

VoidValue

全部标签

java - MERGE 是 SQL 2008 中的原子语句吗?

我正在使用MERGE语句作为UPSERT添加新记录或更新当前记录。我有多个线程通过多个连接和多个语句(每个线程一个连接和一个语句)驱动数据库。我一次批处理50个语句。在我的测试过程中,我很惊讶地发现duplicatekey违规。我预计这是不可能的,因为MERGE将作为单个事务执行,是吗?我的Java代码如下所示:privatevoidaddBatch(Columnscolumns)throwsSQLException{try{//Setparameters.for(inti=0;i=MaxBatched){statement.executeBatch();batched=0;}}cat