org.skife.jdbi.v2.sqlobject.customizers.TransactionIsolation Maven / Gradle / Ivy
/*
* Copyright (C) 2004 - 2014 Brian McCallister
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.skife.jdbi.v2.sqlobject.customizers;
import org.skife.jdbi.v2.SQLStatement;
import org.skife.jdbi.v2.StatementContext;
import org.skife.jdbi.v2.TransactionIsolationLevel;
import org.skife.jdbi.v2.sqlobject.SqlStatementCustomizer;
import org.skife.jdbi.v2.sqlobject.SqlStatementCustomizerFactory;
import org.skife.jdbi.v2.sqlobject.SqlStatementCustomizingAnnotation;
import org.skife.jdbi.v2.tweak.BaseStatementCustomizer;
import java.lang.annotation.Annotation;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
import java.lang.reflect.Method;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.SQLException;
/**
* Used to specify the transaction isolation level for an object or method (via annotating the method
* or passing it in as an annotated param). If used on a parameter, the parameter type must be a
* {@link org.skife.jdbi.v2.TransactionIsolationLevel}
*/
@SqlStatementCustomizingAnnotation(TransactionIsolation.Factory.class)
@Target({ElementType.PARAMETER, ElementType.METHOD, ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
public @interface TransactionIsolation
{
TransactionIsolationLevel value() default TransactionIsolationLevel.INVALID_LEVEL;
static class Factory implements SqlStatementCustomizerFactory
{
@Override
public SqlStatementCustomizer createForMethod(Annotation annotation, Class sqlObjectType, Method method)
{
return new MyCustomizer(((TransactionIsolation) annotation).value());
}
@Override
public SqlStatementCustomizer createForType(Annotation annotation, Class sqlObjectType)
{
return new MyCustomizer(((TransactionIsolation) annotation).value());
}
@Override
public SqlStatementCustomizer createForParameter(Annotation annotation, Class sqlObjectType, Method method, Object arg)
{
assert arg instanceof TransactionIsolationLevel;
return new MyCustomizer((TransactionIsolationLevel) arg);
}
}
static class MyCustomizer implements SqlStatementCustomizer
{
private final TransactionIsolationLevel level;
public MyCustomizer(TransactionIsolationLevel level) {this.level = level;}
@Override
public void apply(SQLStatement q) throws SQLException
{
final int initial_level = q.getContext().getConnection().getTransactionIsolation();
q.addStatementCustomizer(new BaseStatementCustomizer()
{
@Override
public void beforeExecution(PreparedStatement stmt, StatementContext ctx) throws SQLException
{
setTxnIsolation(ctx, level.intValue());
}
@Override
public void afterExecution(PreparedStatement stmt, StatementContext ctx) throws SQLException
{
setTxnIsolation(ctx, initial_level);
}
private void setTxnIsolation(StatementContext ctx, int level) throws SQLException
{
final Connection c = ctx.getConnection();
if (c.getTransactionIsolation() != level) {
c.setTransactionIsolation(level);
}
}
});
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy