org.soulwing.jdbc.Parameter Maven / Gradle / Ivy
/*
* File created on May 5, 2014
*
* Copyright (c) 2014 Carl Harris, Jr
* and others as noted
*
* 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.soulwing.jdbc;
import java.sql.CallableStatement;
import java.sql.PreparedStatement;
import java.sql.SQLException;
import java.sql.Types;
/**
* An SQL parameter injector.
*
* @author Carl Harris
*/
public class Parameter {
private final int type;
private final Object value;
private final boolean in;
private final boolean out;
/**
* Constructs a new instance.
* @param type parameter type
* @param value parameter value
*/
private Parameter(int type, Object value) {
this(type, value, true, false);
}
/**
* Constructs a new instance.
* @param type parameter type
* @param value parameter value
* @param in flag indicating an input parameter
* @param out flag indicating an output parameter
*/
private Parameter(int type, Object value, boolean in, boolean out) {
this.type = type;
this.value = value;
this.in = in;
this.out = out;
}
/**
* Creates a new input parameter with the given value.
*
* Synonym for {@link #in(Object)}.
*
* @param value value of the parameter
* @return parameter object
*/
public static Parameter with(Object value) {
return new Parameter(Types.NULL, value);
}
/**
* Creates a new input parameter with the given value.
*
* Synonym for {@link #in(Object)}.
*
* @param type SQL type of the parameter
* @param value value of the parameter
* @return parameter object
*/
public static Parameter with(int type, Object value) {
return new Parameter(type, value);
}
/**
* Creates a new input parameter with the given value.
*
* Synonym for {@link #in(Object)}.
*
* @param value value of the parameter
* @return parameter object
*/
public static Parameter in(Object value) {
return in(Types.NULL, value);
}
/**
* Creates a new input parameter with the given value.
*
* Synonym for {@link #in(Object)}.
*
* @param type SQL type of the parameter
* @param value value of the parameter
* @return parameter object
*/
public static Parameter in(int type, Object value) {
return new Parameter(type, value, true, false);
}
/**
* Creates a new output parameter with the given type.
* @param type SQL type of the parameter
* @return parameter object
*/
public static Parameter out(int type) {
return new Parameter(type, null, false, true);
}
/**
* Creates a new input/output parameter with the given type.
* @param type SQL type of the parameter
* @param value value of the parameter
* @return parameter object
*/
public static Parameter inout(int type, Object value) {
return new Parameter(type, value, true, true);
}
/**
* Injects this parameter into the given prepared statement.
* @param parameterIndex index of the statement placeholder (starts at 1)
* @param statement target statement
* @throws SQLException
*/
public void inject(int parameterIndex, PreparedStatement statement)
throws SQLException {
if (!in) return;
if (value == null) {
statement.setNull(parameterIndex, Types.NULL);
}
else if (type == Types.NULL) {
statement.setObject(parameterIndex, value);
}
else {
statement.setObject(parameterIndex, value, type);
}
}
/**
* Injects this parameter into the given callable statement.
* @param parameterIndex index of the statement placeholder (starts at 1)
* @param statement target statement
* @throws SQLException
*/
public void inject(int parameterIndex, CallableStatement statement)
throws SQLException {
inject(parameterIndex, (PreparedStatement) statement);
if (out) {
statement.registerOutParameter(parameterIndex, type);
}
}
/**
* Gets the {@code type} property.
* @return property value
*/
public int getType() {
return type;
}
/**
* Gets the {@code value} property.
* @return property value
*/
public Object getValue() {
return value;
}
/**
* Gets the {@code in} property.
* @return property value
*/
boolean isIn() {
return in;
}
/**
* Gets the {@code out} property.
* @return property value
*/
boolean isOut() {
return out;
}
}