JDBI批量操作是原子性的吗?

5
JDBI批量操作(插入或更新)是否具有原子性?还是我需要将它们包装在事务块中?
3个回答

3

我的测试表明,JDBI批处理操作不是原子性的。如果我们想要全有或全无的操作,我们需要将批处理放入事务中。

我创建了一个简单的测试示例。我使用了一个InnoDB类型的MySQL数据库。

package com.zetcode;

import org.skife.jdbi.v2.Batch;
import org.skife.jdbi.v2.DBI;
import org.skife.jdbi.v2.Handle;

public class JDBIEx6 {

    public static void main(String[] args) {

        DBI dbi = new DBI("jdbc:mysql://localhost:3306/testdb",
                "testuser", "test623");

        Handle handle = dbi.open();
        Batch batch = handle.createBatch();

        batch.add("DROP TABLE IF EXISTS Friends");
        batch.add("CREATE TABLE Friends(Id INT AUTO_INCREMENT PRIMARY KEY, Name TEXT)");
        batch.add("INSERT INTO Friends(Name) VALUES ('Monika')");
        batch.add("INSERT INTO Friends(Name) VALUES ('Tom')");
        batch.add("INSERT INTO Friends(Name) VALUES ('Jane')");
        batch.add("INSERT INTO Friends(Name) VALUES ('Robert')");

        batch.execute();
    }
}

如果我们有意修改其中一个INSERT语句使其失败,表将被创建并保存所有正确的INSERT语句。
以下是该项目的Maven POM文件。
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>com.zetcode</groupId>
    <artifactId>JDBIEx6</artifactId>
    <version>1.0-SNAPSHOT</version>
    <packaging>jar</packaging>
    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <maven.compiler.source>1.8</maven.compiler.source>
        <maven.compiler.target>1.8</maven.compiler.target>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.jdbi</groupId>
            <artifactId>jdbi</artifactId>
            <version>2.73</version>
        </dependency>

        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.39</version>
        </dependency>

    </dependencies>    
</project>

因此,我质疑批处理操作默认情况下是否具有原子性。


首先,非常感谢您测试这个! 其次,您(或其他人)是否知道如何将批处理包装在事务中? - GitProphet

3
根据Java文档,默认情况下它是事务性的。我不知道它是否符合原子性的描述,但您不需要将它们包装在事务块中。(顺便说一句,如果您想在DAO级别上执行某些事务操作,则可以使用@Transaction注释,这比事务块更好用)

Java文档的链接目前已经损坏;这里是版本3中等效类的一个 - GitProphet

0

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接