From e00de8c19f017f0426da93257a17a905f2dacd80 Mon Sep 17 00:00:00 2001 From: Gian Merlino Date: Mon, 16 Feb 2015 07:41:40 -0800 Subject: [PATCH] Use jdbi inTransaction for SQLMetadataConnector's insertOrUpdate. This fixes an issue where failed transactions were not properly rolled back. --- .../io/druid/metadata/SQLMetadataConnector.java | 14 +++++--------- 1 file changed, 5 insertions(+), 9 deletions(-) diff --git a/server/src/main/java/io/druid/metadata/SQLMetadataConnector.java b/server/src/main/java/io/druid/metadata/SQLMetadataConnector.java index 4a7d7122825..43c37415b54 100644 --- a/server/src/main/java/io/druid/metadata/SQLMetadataConnector.java +++ b/server/src/main/java/io/druid/metadata/SQLMetadataConnector.java @@ -26,11 +26,12 @@ import org.skife.jdbi.v2.Batch; import org.skife.jdbi.v2.DBI; import org.skife.jdbi.v2.Handle; import org.skife.jdbi.v2.IDBI; +import org.skife.jdbi.v2.TransactionCallback; +import org.skife.jdbi.v2.TransactionStatus; import org.skife.jdbi.v2.tweak.HandleCallback; import org.skife.jdbi.v2.util.ByteArrayMapper; import org.skife.jdbi.v2.util.IntegerMapper; -import java.sql.Connection; import java.util.List; public abstract class SQLMetadataConnector implements MetadataStorageConnector @@ -248,15 +249,12 @@ public abstract class SQLMetadataConnector implements MetadataStorageConnector final byte[] value ) throws Exception { - return getDBI().withHandle( - new HandleCallback() + return getDBI().inTransaction( + new TransactionCallback() { @Override - public Void withHandle(Handle handle) throws Exception + public Void inTransaction(Handle handle, TransactionStatus transactionStatus) throws Exception { - Connection conn = getDBI().open().getConnection(); - handle.begin(); - conn.setAutoCommit(false); int count = handle .createQuery( String.format("SELECT COUNT(*) FROM %1$s WHERE %2$s = :key", tableName, keyColumn) @@ -277,8 +275,6 @@ public abstract class SQLMetadataConnector implements MetadataStorageConnector .bind("value", value) .execute(); } - conn.setAutoCommit(true); - handle.commit(); return null; } }