All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.landawn.abacus.jdbc.NamedQuery Maven / Gradle / Ivy

There is a newer version: 3.8.8
Show newest version
/*
 * Copyright (c) 2020, Haiyang Li.
 *
 * 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 com.landawn.abacus.jdbc;

import java.io.InputStream;
import java.io.Reader;
import java.math.BigDecimal;
import java.math.BigInteger;
import java.net.URL;
import java.sql.PreparedStatement;
import java.sql.SQLException;
import java.sql.SQLType;
import java.sql.Types;
import java.util.Collection;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Set;

import com.landawn.abacus.annotation.Beta;
import com.landawn.abacus.parser.ParserUtil;
import com.landawn.abacus.parser.ParserUtil.BeanInfo;
import com.landawn.abacus.parser.ParserUtil.PropInfo;
import com.landawn.abacus.type.Type;
import com.landawn.abacus.util.ClassUtil;
import com.landawn.abacus.util.EntityId;
import com.landawn.abacus.util.IntList;
import com.landawn.abacus.util.N;
import com.landawn.abacus.util.ParsedSql;

/**
 * The backed {@code PreparedStatement/CallableStatement} will be closed by default
 * after any execution methods(which will trigger the backed {@code PreparedStatement/CallableStatement} to be executed, for example: get/query/queryForInt/Long/../findFirst/findOnlyOne/list/execute/...).
 * except the {@code 'closeAfterExecution'} flag is set to {@code false} by calling {@code #closeAfterExecution(false)}.
 *
 * 
* Generally, don't cache or reuse the instance of this class, * except the {@code 'closeAfterExecution'} flag is set to {@code false} by calling {@code #closeAfterExecution(false)}. * *
* The {@code ResultSet} returned by query will always be closed after execution, even {@code 'closeAfterExecution'} flag is set to {@code false}. * *
* Remember: parameter/column index in {@code PreparedStatement/ResultSet} starts from 1, not 0. * * @author haiyangl * * @see {@link com.landawn.abacus.annotation.ReadOnly} * @see {@link com.landawn.abacus.annotation.ReadOnlyId} * @see {@link com.landawn.abacus.annotation.NonUpdatable} * @see {@link com.landawn.abacus.annotation.Transient} * @see {@link com.landawn.abacus.annotation.Table} * @see {@link com.landawn.abacus.annotation.Column} * * @see http://docs.oracle.com/javase/8/docs/api/java/sql/Connection.html * @see http://docs.oracle.com/javase/8/docs/api/java/sql/Statement.html * @see http://docs.oracle.com/javase/8/docs/api/java/sql/PreparedStatement.html * @see http://docs.oracle.com/javase/8/docs/api/java/sql/ResultSet.html */ public final class NamedQuery extends AbstractQuery { static final int MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP = 5; private final ParsedSql namedSql; private final List parameterNames; private final int parameterCount; private Map paramNameIndexMap; NamedQuery(final PreparedStatement stmt, final ParsedSql namedSql) { super(stmt); this.namedSql = namedSql; this.parameterNames = namedSql.getNamedParameters(); this.parameterCount = namedSql.getParameterCount(); if (N.size(namedSql.getNamedParameters()) != parameterCount) { throw new IllegalArgumentException("Invalid named sql: " + namedSql.sql()); } } /** * Inits the param name index map. */ private void initParamNameIndexMap() { paramNameIndexMap = new HashMap<>(parameterCount); int index = 1; for (String paramName : parameterNames) { IntList indexes = paramNameIndexMap.get(paramName); if (indexes == null) { indexes = new IntList(1); paramNameIndexMap.put(paramName, indexes); } indexes.add(index++); } } /** * Sets the null. * * @param parameterName * @param sqlType * @return * @throws SQLException the SQL exception * @see java.sql.Types */ public NamedQuery setNull(final String parameterName, final int sqlType) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setNull(i + 1, sqlType); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); //NOSONAR } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setNull(indexes.get(0), sqlType); } else if (indexes.size() == 2) { setNull(indexes.get(0), sqlType); setNull(indexes.get(1), sqlType); } else if (indexes.size() == 3) { setNull(indexes.get(0), sqlType); setNull(indexes.get(1), sqlType); setNull(indexes.get(2), sqlType); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setNull(indexes.get(i), sqlType); } } } } return this; } /** * Sets the null. * * @param parameterName * @param sqlType * @param typeName * @return * @throws SQLException the SQL exception * @see java.sql.Types */ public NamedQuery setNull(final String parameterName, final int sqlType, String typeName) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setNull(i + 1, sqlType, typeName); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setNull(indexes.get(0), sqlType, typeName); } else if (indexes.size() == 2) { setNull(indexes.get(0), sqlType, typeName); setNull(indexes.get(1), sqlType, typeName); } else if (indexes.size() == 3) { setNull(indexes.get(0), sqlType, typeName); setNull(indexes.get(1), sqlType, typeName); setNull(indexes.get(2), sqlType, typeName); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setNull(indexes.get(i), sqlType, typeName); } } } } return this; } /** * Sets the boolean. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setBoolean(final String parameterName, final boolean x) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setBoolean(i + 1, x); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setBoolean(indexes.get(0), x); } else if (indexes.size() == 2) { setBoolean(indexes.get(0), x); setBoolean(indexes.get(1), x); } else if (indexes.size() == 3) { setBoolean(indexes.get(0), x); setBoolean(indexes.get(1), x); setBoolean(indexes.get(2), x); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setBoolean(indexes.get(i), x); } } } } return this; } /** * Sets the boolean. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setBoolean(final String parameterName, final Boolean x) throws SQLException { if (x == null) { setNull(parameterName, java.sql.Types.BOOLEAN); } else { setBoolean(parameterName, x.booleanValue()); } return this; } /** * Sets the byte. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setByte(final String parameterName, final byte x) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setByte(i + 1, x); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setByte(indexes.get(0), x); } else if (indexes.size() == 2) { setByte(indexes.get(0), x); setByte(indexes.get(1), x); } else if (indexes.size() == 3) { setByte(indexes.get(0), x); setByte(indexes.get(1), x); setByte(indexes.get(2), x); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setByte(indexes.get(i), x); } } } } return this; } /** * Sets the byte. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setByte(final String parameterName, final Byte x) throws SQLException { if (x == null) { setNull(parameterName, java.sql.Types.TINYINT); } else { setByte(parameterName, x.byteValue()); } return this; } /** * Sets the short. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setShort(final String parameterName, final short x) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setShort(i + 1, x); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setShort(indexes.get(0), x); } else if (indexes.size() == 2) { setShort(indexes.get(0), x); setShort(indexes.get(1), x); } else if (indexes.size() == 3) { setShort(indexes.get(0), x); setShort(indexes.get(1), x); setShort(indexes.get(2), x); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setShort(indexes.get(i), x); } } } } return this; } /** * Sets the short. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setShort(final String parameterName, final Short x) throws SQLException { if (x == null) { setNull(parameterName, java.sql.Types.SMALLINT); } else { setShort(parameterName, x.shortValue()); } return this; } /** * Sets the int. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setInt(final String parameterName, final int x) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setInt(i + 1, x); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setInt(indexes.get(0), x); } else if (indexes.size() == 2) { setInt(indexes.get(0), x); setInt(indexes.get(1), x); } else if (indexes.size() == 3) { setInt(indexes.get(0), x); setInt(indexes.get(1), x); setInt(indexes.get(2), x); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setInt(indexes.get(i), x); } } } } return this; } /** * Sets the int. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setInt(final String parameterName, final Integer x) throws SQLException { if (x == null) { setNull(parameterName, java.sql.Types.INTEGER); } else { setInt(parameterName, x.intValue()); } return this; } /** * * * @param parameterName * @param x * @return * @throws SQLException * @see #setString(String, char) * @deprecated generally {@code char} should be saved as {@code String} in db. */ @Deprecated public NamedQuery setInt(final String parameterName, final char x) throws SQLException { return setInt(parameterName, (int) x); } /** * * * @param parameterName * @param x * @return * @throws SQLException * @see #setString(String, Character) * @deprecated generally {@code char} should be saved as {@code String} in db. */ @Deprecated public NamedQuery setInt(final String parameterName, final Character x) throws SQLException { if (x == null) { setNull(parameterName, java.sql.Types.INTEGER); } else { setInt(parameterName, x.charValue()); } return this; } /** * Sets the long. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setLong(final String parameterName, final long x) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setLong(i + 1, x); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setLong(indexes.get(0), x); } else if (indexes.size() == 2) { setLong(indexes.get(0), x); setLong(indexes.get(1), x); } else if (indexes.size() == 3) { setLong(indexes.get(0), x); setLong(indexes.get(1), x); setLong(indexes.get(2), x); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setLong(indexes.get(i), x); } } } } return this; } /** * Sets the long. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setLong(final String parameterName, final Long x) throws SQLException { if (x == null) { setNull(parameterName, java.sql.Types.BIGINT); } else { setLong(parameterName, x.longValue()); } return this; } /** * Sets the long. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setLong(final String parameterName, final BigInteger x) throws SQLException { if (x == null) { setNull(parameterName, java.sql.Types.BIGINT); } else { setLong(parameterName, x.longValueExact()); } return this; } /** * Sets the float. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setFloat(final String parameterName, final float x) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setFloat(i + 1, x); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setFloat(indexes.get(0), x); } else if (indexes.size() == 2) { setFloat(indexes.get(0), x); setFloat(indexes.get(1), x); } else if (indexes.size() == 3) { setFloat(indexes.get(0), x); setFloat(indexes.get(1), x); setFloat(indexes.get(2), x); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setFloat(indexes.get(i), x); } } } } return this; } /** * Sets the float. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setFloat(final String parameterName, final Float x) throws SQLException { if (x == null) { setNull(parameterName, java.sql.Types.FLOAT); } else { setFloat(parameterName, x.floatValue()); } return this; } /** * Sets the double. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setDouble(final String parameterName, final double x) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setDouble(i + 1, x); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setDouble(indexes.get(0), x); } else if (indexes.size() == 2) { setDouble(indexes.get(0), x); setDouble(indexes.get(1), x); } else if (indexes.size() == 3) { setDouble(indexes.get(0), x); setDouble(indexes.get(1), x); setDouble(indexes.get(2), x); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setDouble(indexes.get(i), x); } } } } return this; } /** * Sets the double. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setDouble(final String parameterName, final Double x) throws SQLException { if (x == null) { setNull(parameterName, java.sql.Types.DOUBLE); } else { setDouble(parameterName, x.doubleValue()); } return this; } /** * Sets the big decimal. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setBigDecimal(final String parameterName, final BigDecimal x) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setBigDecimal(i + 1, x); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setBigDecimal(indexes.get(0), x); } else if (indexes.size() == 2) { setBigDecimal(indexes.get(0), x); setBigDecimal(indexes.get(1), x); } else if (indexes.size() == 3) { setBigDecimal(indexes.get(0), x); setBigDecimal(indexes.get(1), x); setBigDecimal(indexes.get(2), x); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setBigDecimal(indexes.get(i), x); } } } } return this; } /** * * * @param parameterName * @param x * @return * @throws SQLException */ public NamedQuery setBigDecimal(final String parameterName, final BigInteger x) throws SQLException { if (x == null) { return setNull(parameterName, Types.DECIMAL); } else { return setBigDecimal(parameterName, new BigDecimal(x)); } } /** * Sets the BigInteger. * * @param parameterName * @param x * @return * @throws SQLException * @see {@link #setString(String, BigInteger)} * @see {@link #setBigDecimal(String, BigInteger)} * @see {@link #setLong(String, BigInteger)} */ @Beta public NamedQuery setBigIntegerAsString(final String parameterName, final BigInteger x) throws SQLException { return setString(parameterName, x); } /** * Sets the string. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setString(final String parameterName, final String x) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setString(i + 1, x); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setString(indexes.get(0), x); } else if (indexes.size() == 2) { setString(indexes.get(0), x); setString(indexes.get(1), x); } else if (indexes.size() == 3) { setString(indexes.get(0), x); setString(indexes.get(1), x); setString(indexes.get(2), x); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setString(indexes.get(i), x); } } } } return this; } /** * * * @param parameterName * @param x * @return * @throws SQLException */ public NamedQuery setString(final String parameterName, final CharSequence x) throws SQLException { return setString(parameterName, x == null ? (String) null : x.toString()); //NOSONAR } /** * * * @param parameterName * @param x * @return * @throws SQLException */ public NamedQuery setString(final String parameterName, final char x) throws SQLException { return setString(parameterName, String.valueOf(x)); } /** * * * @param parameterName * @param x * @return * @throws SQLException */ public NamedQuery setString(final String parameterName, final Character x) throws SQLException { return setString(parameterName, x == null ? (String) null : x.toString()); //NOSONAR } /** * * * @param parameterName * @param x * @return * @throws SQLException */ public NamedQuery setString(final String parameterName, final BigInteger x) throws SQLException { if (x == null) { return setNull(parameterName, Types.VARCHAR); } else { return setString(parameterName, x.toString(10)); } } /** * Sets the string. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setNString(final String parameterName, final String x) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setNString(i + 1, x); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setNString(indexes.get(0), x); } else if (indexes.size() == 2) { setNString(indexes.get(0), x); setNString(indexes.get(1), x); } else if (indexes.size() == 3) { setNString(indexes.get(0), x); setNString(indexes.get(1), x); setNString(indexes.get(2), x); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setNString(indexes.get(i), x); } } } } return this; } /** * Sets the string. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setNString(final String parameterName, final CharSequence x) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setNString(i + 1, x); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setNString(indexes.get(0), x); } else if (indexes.size() == 2) { setNString(indexes.get(0), x); setNString(indexes.get(1), x); } else if (indexes.size() == 3) { setNString(indexes.get(0), x); setNString(indexes.get(1), x); setNString(indexes.get(2), x); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setNString(indexes.get(i), x); } } } } return this; } /** * Sets the date. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setDate(final String parameterName, final java.sql.Date x) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setDate(i + 1, x); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setDate(indexes.get(0), x); } else if (indexes.size() == 2) { setDate(indexes.get(0), x); setDate(indexes.get(1), x); } else if (indexes.size() == 3) { setDate(indexes.get(0), x); setDate(indexes.get(1), x); setDate(indexes.get(2), x); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setDate(indexes.get(i), x); } } } } return this; } /** * Sets the date. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setDate(final String parameterName, final java.util.Date x) throws SQLException { setDate(parameterName, x == null ? null : x instanceof java.sql.Date ? (java.sql.Date) x : new java.sql.Date(x.getTime())); return this; } /** * Sets the time. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setTime(final String parameterName, final java.sql.Time x) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setTime(i + 1, x); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setTime(indexes.get(0), x); } else if (indexes.size() == 2) { setTime(indexes.get(0), x); setTime(indexes.get(1), x); } else if (indexes.size() == 3) { setTime(indexes.get(0), x); setTime(indexes.get(1), x); setTime(indexes.get(2), x); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setTime(indexes.get(i), x); } } } } return this; } /** * Sets the time. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setTime(final String parameterName, final java.util.Date x) throws SQLException { setTime(parameterName, x == null ? null : x instanceof java.sql.Time ? (java.sql.Time) x : new java.sql.Time(x.getTime())); return this; } /** * Sets the timestamp. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setTimestamp(final String parameterName, final java.sql.Timestamp x) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setTimestamp(i + 1, x); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setTimestamp(indexes.get(0), x); } else if (indexes.size() == 2) { setTimestamp(indexes.get(0), x); setTimestamp(indexes.get(1), x); } else if (indexes.size() == 3) { setTimestamp(indexes.get(0), x); setTimestamp(indexes.get(1), x); setTimestamp(indexes.get(2), x); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setTimestamp(indexes.get(i), x); } } } } return this; } /** * Sets the timestamp. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setTimestamp(final String parameterName, final java.util.Date x) throws SQLException { setTimestamp(parameterName, x == null ? null : x instanceof java.sql.Timestamp ? (java.sql.Timestamp) x : new java.sql.Timestamp(x.getTime())); return this; } /** * Sets the bytes. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setBytes(final String parameterName, final byte[] x) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setBytes(i + 1, x); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setBytes(indexes.get(0), x); } else if (indexes.size() == 2) { setBytes(indexes.get(0), x); setBytes(indexes.get(1), x); } else if (indexes.size() == 3) { setBytes(indexes.get(0), x); setBytes(indexes.get(1), x); setBytes(indexes.get(2), x); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setBytes(indexes.get(i), x); } } } } return this; } /** * Sets the ascii stream. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setAsciiStream(final String parameterName, final InputStream x) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setAsciiStream(i + 1, x); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setAsciiStream(indexes.get(0), x); } else if (indexes.size() == 2) { setAsciiStream(indexes.get(0), x); setAsciiStream(indexes.get(1), x); } else if (indexes.size() == 3) { setAsciiStream(indexes.get(0), x); setAsciiStream(indexes.get(1), x); setAsciiStream(indexes.get(2), x); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setAsciiStream(indexes.get(i), x); } } } } return this; } /** * Sets the ascii stream. * * @param parameterName * @param x * @param length * @return * @throws SQLException the SQL exception */ public NamedQuery setAsciiStream(final String parameterName, final InputStream x, final long length) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setAsciiStream(i + 1, x, length); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setAsciiStream(indexes.get(0), x, length); } else if (indexes.size() == 2) { setAsciiStream(indexes.get(0), x, length); setAsciiStream(indexes.get(1), x, length); } else if (indexes.size() == 3) { setAsciiStream(indexes.get(0), x, length); setAsciiStream(indexes.get(1), x, length); setAsciiStream(indexes.get(2), x, length); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setAsciiStream(indexes.get(i), x, length); } } } } return this; } /** * Sets the binary stream. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setBinaryStream(final String parameterName, final InputStream x) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setBinaryStream(i + 1, x); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setBinaryStream(indexes.get(0), x); } else if (indexes.size() == 2) { setBinaryStream(indexes.get(0), x); setBinaryStream(indexes.get(1), x); } else if (indexes.size() == 3) { setBinaryStream(indexes.get(0), x); setBinaryStream(indexes.get(1), x); setBinaryStream(indexes.get(2), x); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setBinaryStream(indexes.get(i), x); } } } } return this; } /** * Sets the binary stream. * * @param parameterName * @param x * @param length * @return * @throws SQLException the SQL exception */ public NamedQuery setBinaryStream(final String parameterName, final InputStream x, final long length) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setBinaryStream(i + 1, x, length); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setBinaryStream(indexes.get(0), x, length); } else if (indexes.size() == 2) { setBinaryStream(indexes.get(0), x, length); setBinaryStream(indexes.get(1), x, length); } else if (indexes.size() == 3) { setBinaryStream(indexes.get(0), x, length); setBinaryStream(indexes.get(1), x, length); setBinaryStream(indexes.get(2), x, length); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setBinaryStream(indexes.get(i), x, length); } } } } return this; } /** * Sets the character stream. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setCharacterStream(final String parameterName, final Reader x) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setCharacterStream(i + 1, x); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setCharacterStream(indexes.get(0), x); } else if (indexes.size() == 2) { setCharacterStream(indexes.get(0), x); setCharacterStream(indexes.get(1), x); } else if (indexes.size() == 3) { setCharacterStream(indexes.get(0), x); setCharacterStream(indexes.get(1), x); setCharacterStream(indexes.get(2), x); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setCharacterStream(indexes.get(i), x); } } } } return this; } /** * Sets the character stream. * * @param parameterName * @param x * @param length * @return * @throws SQLException the SQL exception */ public NamedQuery setCharacterStream(final String parameterName, final Reader x, final long length) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setCharacterStream(i + 1, x, length); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setCharacterStream(indexes.get(0), x, length); } else if (indexes.size() == 2) { setCharacterStream(indexes.get(0), x, length); setCharacterStream(indexes.get(1), x, length); } else if (indexes.size() == 3) { setCharacterStream(indexes.get(0), x, length); setCharacterStream(indexes.get(1), x, length); setCharacterStream(indexes.get(2), x, length); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setCharacterStream(indexes.get(i), x, length); } } } } return this; } /** * Sets the N character stream. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setNCharacterStream(final String parameterName, final Reader x) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setNCharacterStream(i + 1, x); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setNCharacterStream(indexes.get(0), x); } else if (indexes.size() == 2) { setNCharacterStream(indexes.get(0), x); setNCharacterStream(indexes.get(1), x); } else if (indexes.size() == 3) { setNCharacterStream(indexes.get(0), x); setNCharacterStream(indexes.get(1), x); setNCharacterStream(indexes.get(2), x); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setNCharacterStream(indexes.get(i), x); } } } } return this; } /** * Sets the N character stream. * * @param parameterName * @param x * @param length * @return * @throws SQLException the SQL exception */ public NamedQuery setNCharacterStream(final String parameterName, final Reader x, final long length) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setNCharacterStream(i + 1, x, length); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setNCharacterStream(indexes.get(0), x, length); } else if (indexes.size() == 2) { setNCharacterStream(indexes.get(0), x, length); setNCharacterStream(indexes.get(1), x, length); } else if (indexes.size() == 3) { setNCharacterStream(indexes.get(0), x, length); setNCharacterStream(indexes.get(1), x, length); setNCharacterStream(indexes.get(2), x, length); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setNCharacterStream(indexes.get(i), x, length); } } } } return this; } /** * Sets the blob. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setBlob(final String parameterName, final java.sql.Blob x) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setBlob(i + 1, x); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setBlob(indexes.get(0), x); } else if (indexes.size() == 2) { setBlob(indexes.get(0), x); setBlob(indexes.get(1), x); } else if (indexes.size() == 3) { setBlob(indexes.get(0), x); setBlob(indexes.get(1), x); setBlob(indexes.get(2), x); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setBlob(indexes.get(i), x); } } } } return this; } /** * Sets the blob. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setBlob(final String parameterName, final InputStream x) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setBlob(i + 1, x); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setBlob(indexes.get(0), x); } else if (indexes.size() == 2) { setBlob(indexes.get(0), x); setBlob(indexes.get(1), x); } else if (indexes.size() == 3) { setBlob(indexes.get(0), x); setBlob(indexes.get(1), x); setBlob(indexes.get(2), x); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setBlob(indexes.get(i), x); } } } } return this; } /** * Sets the blob. * * @param parameterName * @param x * @param length * @return * @throws SQLException the SQL exception */ public NamedQuery setBlob(final String parameterName, final InputStream x, final long length) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setBlob(i + 1, x, length); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setBlob(indexes.get(0), x, length); } else if (indexes.size() == 2) { setBlob(indexes.get(0), x, length); setBlob(indexes.get(1), x, length); } else if (indexes.size() == 3) { setBlob(indexes.get(0), x, length); setBlob(indexes.get(1), x, length); setBlob(indexes.get(2), x, length); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setBlob(indexes.get(i), x, length); } } } } return this; } /** * Sets the clob. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setClob(final String parameterName, final java.sql.Clob x) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setClob(i + 1, x); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setClob(indexes.get(0), x); } else if (indexes.size() == 2) { setClob(indexes.get(0), x); setClob(indexes.get(1), x); } else if (indexes.size() == 3) { setClob(indexes.get(0), x); setClob(indexes.get(1), x); setClob(indexes.get(2), x); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setClob(indexes.get(i), x); } } } } return this; } /** * Sets the clob. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setClob(final String parameterName, final Reader x) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setClob(i + 1, x); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setClob(indexes.get(0), x); } else if (indexes.size() == 2) { setClob(indexes.get(0), x); setClob(indexes.get(1), x); } else if (indexes.size() == 3) { setClob(indexes.get(0), x); setClob(indexes.get(1), x); setClob(indexes.get(2), x); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setClob(indexes.get(i), x); } } } } return this; } /** * Sets the clob. * * @param parameterName * @param x * @param length * @return * @throws SQLException the SQL exception */ public NamedQuery setClob(final String parameterName, final Reader x, final long length) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setClob(i + 1, x, length); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setClob(indexes.get(0), x, length); } else if (indexes.size() == 2) { setClob(indexes.get(0), x, length); setClob(indexes.get(1), x, length); } else if (indexes.size() == 3) { setClob(indexes.get(0), x, length); setClob(indexes.get(1), x, length); setClob(indexes.get(2), x, length); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setClob(indexes.get(i), x, length); } } } } return this; } /** * Sets the N clob. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setNClob(final String parameterName, final java.sql.NClob x) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setNClob(i + 1, x); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setNClob(indexes.get(0), x); } else if (indexes.size() == 2) { setNClob(indexes.get(0), x); setNClob(indexes.get(1), x); } else if (indexes.size() == 3) { setNClob(indexes.get(0), x); setNClob(indexes.get(1), x); setNClob(indexes.get(2), x); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setNClob(indexes.get(i), x); } } } } return this; } /** * Sets the N clob. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setNClob(final String parameterName, final Reader x) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setNClob(i + 1, x); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setNClob(indexes.get(0), x); } else if (indexes.size() == 2) { setNClob(indexes.get(0), x); setNClob(indexes.get(1), x); } else if (indexes.size() == 3) { setNClob(indexes.get(0), x); setNClob(indexes.get(1), x); setNClob(indexes.get(2), x); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setNClob(indexes.get(i), x); } } } } return this; } /** * Sets the N clob. * * @param parameterName * @param x * @param length * @return * @throws SQLException the SQL exception */ public NamedQuery setNClob(final String parameterName, final Reader x, final long length) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setNClob(i + 1, x, length); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setNClob(indexes.get(0), x, length); } else if (indexes.size() == 2) { setNClob(indexes.get(0), x, length); setNClob(indexes.get(1), x, length); } else if (indexes.size() == 3) { setNClob(indexes.get(0), x, length); setNClob(indexes.get(1), x, length); setNClob(indexes.get(2), x, length); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setNClob(indexes.get(i), x, length); } } } } return this; } /** * * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setURL(final String parameterName, final URL x) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setURL(i + 1, x); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setURL(indexes.get(0), x); } else if (indexes.size() == 2) { setURL(indexes.get(0), x); setURL(indexes.get(1), x); } else if (indexes.size() == 3) { setURL(indexes.get(0), x); setURL(indexes.get(1), x); setURL(indexes.get(2), x); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setURL(indexes.get(i), x); } } } } return this; } /** * * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setSQLXML(final String parameterName, final java.sql.SQLXML x) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setSQLXML(i + 1, x); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setSQLXML(indexes.get(0), x); } else if (indexes.size() == 2) { setSQLXML(indexes.get(0), x); setSQLXML(indexes.get(1), x); } else if (indexes.size() == 3) { setSQLXML(indexes.get(0), x); setSQLXML(indexes.get(1), x); setSQLXML(indexes.get(2), x); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setSQLXML(indexes.get(i), x); } } } } return this; } /** * * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setRowId(final String parameterName, final java.sql.RowId x) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setRowId(i + 1, x); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setRowId(indexes.get(0), x); } else if (indexes.size() == 2) { setRowId(indexes.get(0), x); setRowId(indexes.get(1), x); } else if (indexes.size() == 3) { setRowId(indexes.get(0), x); setRowId(indexes.get(1), x); setRowId(indexes.get(2), x); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setRowId(indexes.get(i), x); } } } } return this; } /** * * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setRef(final String parameterName, final java.sql.Ref x) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setRef(i + 1, x); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setRef(indexes.get(0), x); } else if (indexes.size() == 2) { setRef(indexes.get(0), x); setRef(indexes.get(1), x); } else if (indexes.size() == 3) { setRef(indexes.get(0), x); setRef(indexes.get(1), x); setRef(indexes.get(2), x); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setRef(indexes.get(i), x); } } } } return this; } /** * * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setArray(final String parameterName, final java.sql.Array x) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setArray(i + 1, x); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setArray(indexes.get(0), x); } else if (indexes.size() == 2) { setArray(indexes.get(0), x); setArray(indexes.get(1), x); } else if (indexes.size() == 3) { setArray(indexes.get(0), x); setArray(indexes.get(1), x); setArray(indexes.get(2), x); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setArray(indexes.get(i), x); } } } } return this; } /** * Sets the object. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public NamedQuery setObject(final String parameterName, final Object x) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setObject(i + 1, x); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setObject(indexes.get(0), x); } else if (indexes.size() == 2) { setObject(indexes.get(0), x); setObject(indexes.get(1), x); } else if (indexes.size() == 3) { setObject(indexes.get(0), x); setObject(indexes.get(1), x); setObject(indexes.get(2), x); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setObject(indexes.get(i), x); } } } } return this; } /** * Sets the object. * * @param parameterName * @param x * @param sqlType * @return * @throws SQLException the SQL exception * @see java.sql.Types */ public NamedQuery setObject(final String parameterName, final Object x, final int sqlType) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setObject(i + 1, x, sqlType); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setObject(indexes.get(0), x, sqlType); } else if (indexes.size() == 2) { setObject(indexes.get(0), x, sqlType); setObject(indexes.get(1), x, sqlType); } else if (indexes.size() == 3) { setObject(indexes.get(0), x, sqlType); setObject(indexes.get(1), x, sqlType); setObject(indexes.get(2), x, sqlType); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setObject(indexes.get(i), x, sqlType); } } } } return this; } /** * Sets the object. * * @param parameterName * @param x * @param sqlType * @param scaleOrLength * @return * @throws SQLException the SQL exception * @see java.sql.Types */ public NamedQuery setObject(final String parameterName, final Object x, final int sqlType, final int scaleOrLength) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setObject(i + 1, x, sqlType, scaleOrLength); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setObject(indexes.get(0), x, sqlType, scaleOrLength); } else if (indexes.size() == 2) { setObject(indexes.get(0), x, sqlType, scaleOrLength); setObject(indexes.get(1), x, sqlType, scaleOrLength); } else if (indexes.size() == 3) { setObject(indexes.get(0), x, sqlType, scaleOrLength); setObject(indexes.get(1), x, sqlType, scaleOrLength); setObject(indexes.get(2), x, sqlType, scaleOrLength); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setObject(indexes.get(i), x, sqlType, scaleOrLength); } } } } return this; } /** * Sets the object. * * @param parameterName * @param x * @param sqlType * @return * @throws SQLException the SQL exception */ public NamedQuery setObject(final String parameterName, final Object x, final SQLType sqlType) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setObject(i + 1, x, sqlType); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setObject(indexes.get(0), x, sqlType); } else if (indexes.size() == 2) { setObject(indexes.get(0), x, sqlType); setObject(indexes.get(1), x, sqlType); } else if (indexes.size() == 3) { setObject(indexes.get(0), x, sqlType); setObject(indexes.get(1), x, sqlType); setObject(indexes.get(2), x, sqlType); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setObject(indexes.get(i), x, sqlType); } } } } return this; } /** * Sets the object. * * @param parameterName * @param x * @param sqlType * @param scaleOrLength * @return * @throws SQLException the SQL exception */ public NamedQuery setObject(final String parameterName, final Object x, final SQLType sqlType, final int scaleOrLength) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { setObject(i + 1, x, sqlType, scaleOrLength); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { setObject(indexes.get(0), x, sqlType, scaleOrLength); } else if (indexes.size() == 2) { setObject(indexes.get(0), x, sqlType, scaleOrLength); setObject(indexes.get(1), x, sqlType, scaleOrLength); } else if (indexes.size() == 3) { setObject(indexes.get(0), x, sqlType, scaleOrLength); setObject(indexes.get(1), x, sqlType, scaleOrLength); setObject(indexes.get(2), x, sqlType, scaleOrLength); } else { for (int i = 0, size = indexes.size(); i < size; i++) { setObject(indexes.get(i), x, sqlType, scaleOrLength); } } } } return this; } /** * Sets the object. * * @param parameterName * @param x * @param type * @return * @throws SQLException the SQL exception */ public NamedQuery setObject(final String parameterName, final Object x, final Type type) throws SQLException { if (parameterCount < MIN_PARAMETER_COUNT_FOR_INDEX_BY_MAP) { int cnt = 0; for (int i = 0; i < parameterCount; i++) { if (parameterNames.get(i).equals(parameterName)) { type.set(stmt, i + 1, x); cnt++; } } if (cnt == 0) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } } else { if (paramNameIndexMap == null) { initParamNameIndexMap(); } final IntList indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { type.set(stmt, indexes.get(0), x); } else if (indexes.size() == 2) { type.set(stmt, indexes.get(0), x); type.set(stmt, indexes.get(1), x); } else if (indexes.size() == 3) { type.set(stmt, indexes.get(0), x); type.set(stmt, indexes.get(1), x); type.set(stmt, indexes.get(2), x); } else { for (int i = 0, size = indexes.size(); i < size; i++) { type.set(stmt, indexes.get(i), x); } } } } return this; } /** * Sets the parameters. * * @param parameters * @return * @throws IllegalArgumentException * @throws SQLException the SQL exception */ public NamedQuery setParameters(final Map parameters) throws IllegalArgumentException, SQLException { checkArgNotNull(parameters, "parameters"); for (String paramName : parameterNames) { if (parameters.containsKey(paramName)) { setObject(paramName, parameters.get(paramName)); } } return this; } void setParameters(EntityId entityId) throws SQLException { for (String paramName : parameterNames) { if (entityId.containsKey(paramName)) { setObject(paramName, entityId.get(paramName)); } } } /** * Sets the parameters. * * @param parameters with getter/setter methods * @return * @throws IllegalArgumentException * @throws SQLException the SQL exception */ @SuppressWarnings("rawtypes") public NamedQuery setParameters(final Object parameters) throws IllegalArgumentException, SQLException { checkArgNotNull(parameters, "parameters"); final Class cls = parameters.getClass(); if (ClassUtil.isBeanClass(cls)) { final BeanInfo entityInfo = ParserUtil.getBeanInfo(cls); PropInfo propInfo = null; for (int i = 0; i < parameterCount; i++) { propInfo = entityInfo.getPropInfo(parameterNames.get(i)); if (propInfo != null) { propInfo.dbType.set(stmt, i + 1, propInfo.getPropValue(parameters)); } } } else if (parameters instanceof Map) { return setParameters((Map) parameters); } else if (parameters instanceof Collection) { return setParameters((Collection) parameters); } else if (parameters instanceof Object[]) { return setParameters((Object[]) parameters); } else if (parameters instanceof EntityId) { setParameters((EntityId) parameters); } else if (parameterCount == 1) { setObject(1, parameters); } else { close(); throw new IllegalArgumentException("Unsupported named parameter type: " + parameters.getClass() + " for named sql: " + namedSql.sql()); } return this; } /** * Sets the parameters. * * @param entity * @param parameterNames * @return * @throws IllegalArgumentException * @throws SQLException the SQL exception * @see {@link ClassUtil#getPropNameList(Class)} * @see {@link ClassUtil#getPropNameListExclusively(Class, Set)} * @see {@link ClassUtil#getPropNameListExclusively(Class, Collection)} * @see {@link JdbcUtil#getNamedParameters(String)} */ public NamedQuery setParameters(final Object entity, final Collection parameterNames) throws IllegalArgumentException, SQLException { checkArgNotNull(entity, "entity"); checkArgNotNull(parameterNames, "parameterNames"); if (paramNameIndexMap == null) { initParamNameIndexMap(); } final Class cls = entity.getClass(); if (ClassUtil.isBeanClass(cls)) { final BeanInfo entityInfo = ParserUtil.getBeanInfo(cls); PropInfo propInfo = null; Object propValue = null; Type dbType = null; IntList indexes = null; for (String parameterName : parameterNames) { propInfo = entityInfo.getPropInfo(parameterName); if (propInfo == null) { close(); throw new IllegalArgumentException("No property found with name: " + parameterName + " in class: " + ClassUtil.getCanonicalClassName(cls)); } propValue = propInfo.getPropValue(entity); dbType = propInfo.dbType; indexes = paramNameIndexMap.get(parameterName); if (indexes == null) { close(); throw new IllegalArgumentException("Not found named parameter: " + parameterName); } else { if (indexes.size() == 1) { dbType.set(stmt, indexes.get(0), propValue); } else if (indexes.size() == 2) { dbType.set(stmt, indexes.get(0), propValue); dbType.set(stmt, indexes.get(1), propValue); } else if (indexes.size() == 3) { dbType.set(stmt, indexes.get(0), propValue); dbType.set(stmt, indexes.get(1), propValue); dbType.set(stmt, indexes.get(2), propValue); } else { for (int i = 0, size = indexes.size(); i < size; i++) { dbType.set(stmt, indexes.get(i), propValue); } } } } } else { close(); throw new IllegalArgumentException( "Unsupported parameter type: " + ClassUtil.getCanonicalClassName(cls) + ". Only Entity/Record types are supported here"); } return this; } /** * Sets the parameters. * * @param * @param paramaters * @param paramsSetter * @return * @throws IllegalArgumentException * @throws SQLException the SQL exception */ public NamedQuery setParameters(final T paramaters, Jdbc.TriParametersSetter paramsSetter) throws IllegalArgumentException, SQLException { checkArgNotNull(paramsSetter, "paramsSetter"); boolean noException = false; try { paramsSetter.accept(namedSql, this, paramaters); noException = true; } finally { if (!noException) { close(); } } return this; } /** * * * @param batchParameters * @return * @throws IllegalArgumentException * @throws SQLException */ @Override public NamedQuery addBatchParameters(final Collection batchParameters) throws IllegalArgumentException, SQLException { checkArgNotNull(batchParameters, "batchParameters"); if (N.isEmpty(batchParameters)) { return this; } return addBatchParameters(batchParameters.iterator()); } /** * * * @param batchParameters * @return * @throws IllegalArgumentException * @throws SQLException */ @Beta @Override @SuppressWarnings("rawtypes") public NamedQuery addBatchParameters(final Iterator batchParameters) throws IllegalArgumentException, SQLException { checkArgNotNull(batchParameters, "batchParameters"); final Iterator iter = batchParameters; boolean noException = false; try { if (!iter.hasNext()) { return this; } final Object first = iter.next(); if (first == null) { if (parameterCount != 1) { throw new IllegalArgumentException("Unsupported named parameter type: null for named sql: " + namedSql.sql()); } stmt.setObject(1, first); addBatch(); while (iter.hasNext()) { stmt.setObject(1, iter.next()); addBatch(); } } else { final Class cls = first.getClass(); if (ClassUtil.isBeanClass(cls)) { final BeanInfo entityInfo = ParserUtil.getBeanInfo(cls); final PropInfo[] propInfos = new PropInfo[parameterCount]; for (int i = 0; i < parameterCount; i++) { propInfos[i] = entityInfo.getPropInfo(parameterNames.get(i)); } PropInfo propInfo = null; for (int i = 0; i < parameterCount; i++) { propInfo = propInfos[i]; if (propInfo != null) { propInfo.dbType.set(stmt, i + 1, propInfo.getPropValue(first)); } } addBatch(); Object params = null; while (iter.hasNext()) { params = iter.next(); for (int i = 0; i < parameterCount; i++) { propInfo = propInfos[i]; if (propInfo != null) { propInfo.dbType.set(stmt, i + 1, propInfo.getPropValue(params)); } } addBatch(); } } else if (Map.class.isAssignableFrom(cls)) { setParameters((Map) first); addBatch(); Map params = null; while (iter.hasNext()) { params = (Map) iter.next(); setParameters(params); addBatch(); } } else if (first instanceof Collection) { setParameters((Collection) first); addBatch(); Collection params = null; while (iter.hasNext()) { params = (Collection) iter.next(); setParameters(params); addBatch(); } } else if (first instanceof Object[]) { setParameters((Object[]) first); addBatch(); Object[] params = null; while (iter.hasNext()) { params = (Object[]) iter.next(); setParameters(params); addBatch(); } } else if (first instanceof EntityId) { setParameters((EntityId) first); addBatch(); EntityId params = null; while (iter.hasNext()) { params = (EntityId) iter.next(); setParameters(params); addBatch(); } } else if (parameterCount == 1) { stmt.setObject(1, first); addBatch(); while (iter.hasNext()) { stmt.setObject(1, iter.next()); addBatch(); } } else { throw new IllegalArgumentException("Unsupported named parameter type: " + cls + " for named sql: " + namedSql.sql()); } } noException = true; } finally { if (!noException) { close(); } } return this; } // /** // * // * @param batchParameters // * @return // * @throws SQLException the SQL exception // */ // @Override // public NamedQuery addSingleBatchParameters(final Collection batchParameters) throws SQLException { // checkArgNotNull(batchParameters, "batchParameters"); // // if (parameterCount != 1) { // try { // close(); // } catch (Exception e) { // JdbcUtil.logger.error("Failed to close PreparedQuery", e); // } // // throw new IllegalArgumentException("isSingleParameter is true but the count of parameters in query is: " + parameterCount); // } // // if (N.isEmpty(batchParameters)) { // return this; // } // // boolean noException = false; // // try { // for (Object obj : batchParameters) { // setObject(1, obj); // // addBatch(); // } // // isBatch = batchParameters.size() > 0; // // noException = true; // } finally { // if (noException == false) { // close(); // } // } // // return this; // } // // /** // * // * @param batchParameters // * @return // * @throws SQLException the SQL exception // */ // @Override // public NamedQuery addSingleBatchParameters(final Iterator batchParameters) throws SQLException { // checkArgNotNull(batchParameters, "batchParameters"); // // return addSingleBatchParameters(Iterators.toList(batchParameters)); // } }