Java JDBI批处理操作是原子的吗?

Java JDBI批处理操作是原子的吗?,java,mysql,database,jdbi,Java,Mysql,Database,Jdbi,JDBI批处理操作(插入或更新)是原子的吗?或者我需要将它们包装在事务块中吗?根据默认情况,它是事务性的。我不知道它是否满足atomic的描述,但您不需要将它们包装在事务块中。(仅供参考,如果您想在DAO级别执行事务性操作,可以使用@Transaction注释,这比事务块更好)我的测试表明JDBI批处理操作不是原子的。如果我们想要全有或全无操作,我们需要将批处理放入事务中 我创建了一个简单的测试示例。我使用了InnoDB的MySQL数据库 类型 如果我们故意修改其中一条INSERT语句使其失败,

JDBI批处理操作(插入或更新)是原子的吗?或者我需要将它们包装在事务块中吗?

根据默认情况,它是事务性的。我不知道它是否满足atomic的描述,但您不需要将它们包装在事务块中。(仅供参考,如果您想在DAO级别执行事务性操作,可以使用@Transaction注释,这比事务块更好)

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

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

如果我们故意修改其中一条INSERT语句使其失败, 将创建该表并保存所有正确的INSERT语句

以下是该项目的Mavem 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>

4.0.0
com.zetcode
JDBIEx6
1.0-快照
罐子
UTF-8
1.8
1.8
org.jdbi
jdbi
2.73
mysql
mysql连接器java
5.1.39
因此,我质疑一个事实,即批处理操作在默认情况下是原子的。

我认为您不应该将ddl语句放在针对mysql的批处理中,请参阅

create table…
之后有一个隐式提交,它在很大程度上击败了批处理中的MAY-BE事务


只是说…

到现在为止,java文档的链接已经断开了。首先,非常感谢您的测试!其次,您(或其他任何人)知道在事务中包装批的方法吗?
<?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>