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

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

/*
 * 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.CallableStatement;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.SQLType;
import java.sql.Statement;
import java.sql.Timestamp;
import java.sql.Types;
import java.time.Instant;
import java.time.LocalDate;
import java.time.LocalDateTime;
import java.time.LocalTime;
import java.time.OffsetDateTime;
import java.time.ZonedDateTime;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
import java.util.Map;

import com.landawn.abacus.annotation.Beta;
import com.landawn.abacus.jdbc.Jdbc.ResultExtractor;
import com.landawn.abacus.parser.ParserUtil;
import com.landawn.abacus.parser.ParserUtil.BeanInfo;
import com.landawn.abacus.parser.ParserUtil.PropInfo;
import com.landawn.abacus.util.ClassUtil;
import com.landawn.abacus.util.DataSet;
import com.landawn.abacus.util.N;
import com.landawn.abacus.util.Throwables;
import com.landawn.abacus.util.Tuple;
import com.landawn.abacus.util.Tuple.Tuple2;
import com.landawn.abacus.util.Tuple.Tuple3;
import com.landawn.abacus.util.Tuple.Tuple4;
import com.landawn.abacus.util.stream.ObjIteratorEx;

/**
 * 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. * * * @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 Connection * @see Statement * @see PreparedStatement * @see ResultSet */ @SuppressWarnings({ "java:S1192", "resource" }) public final class CallableQuery extends AbstractQuery { final CallableStatement cstmt; List outParams; CallableQuery(final CallableStatement stmt) { super(stmt); cstmt = stmt; } /** * Sets the {@code null}. * * @param parameterName the name of the parameter * @param sqlType the SQL type code defined in {@link java.sql.Types} * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs * @see java.sql.Types */ public CallableQuery setNull(final String parameterName, final int sqlType) throws SQLException { cstmt.setNull(parameterName, sqlType); return this; } /** * Sets the {@code null} value for the specified parameter. * * @param parameterName the name of the parameter * @param sqlType the SQL type code defined in {@link java.sql.Types} * @param typeName the SQL type name * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs * @see java.sql.Types */ public CallableQuery setNull(final String parameterName, final int sqlType, final String typeName) throws SQLException { cstmt.setNull(parameterName, sqlType, typeName); return this; } /** * Sets the boolean value for the specified parameter. * * @param parameterName the name of the parameter * @param x the boolean value to set * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs */ public CallableQuery setBoolean(final String parameterName, final boolean x) throws SQLException { cstmt.setBoolean(parameterName, x); return this; } /** * Sets the boolean value for the specified parameter. * * @param parameterName the name of the parameter * @param x the boolean value to set, or {@code null} to set the parameter to SQL NULL * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs */ public CallableQuery setBoolean(final String parameterName, final Boolean x) throws SQLException { if (x == null) { cstmt.setNull(parameterName, java.sql.Types.BOOLEAN); } else { cstmt.setBoolean(parameterName, x); } return this; } /** * Sets the byte value for the specified parameter. * * @param parameterName the name of the parameter * @param x the byte value to set * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs */ public CallableQuery setByte(final String parameterName, final byte x) throws SQLException { cstmt.setByte(parameterName, x); return this; } /** * Sets the byte value for the specified parameter. * * @param parameterName the name of the parameter * @param x the byte value to set, or {@code null} to set the parameter to SQL NULL * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs */ public CallableQuery setByte(final String parameterName, final Byte x) throws SQLException { if (x == null) { cstmt.setNull(parameterName, java.sql.Types.TINYINT); } else { cstmt.setByte(parameterName, x); } return this; } /** * Sets the short value for the specified parameter. * * @param parameterName the name of the parameter * @param x the short value to set * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs */ public CallableQuery setShort(final String parameterName, final short x) throws SQLException { cstmt.setShort(parameterName, x); return this; } /** * Sets the short value for the specified parameter. * * @param parameterName the name of the parameter * @param x the short value to set, or {@code null} to set the parameter to SQL NULL * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs */ public CallableQuery setShort(final String parameterName, final Short x) throws SQLException { if (x == null) { cstmt.setNull(parameterName, java.sql.Types.SMALLINT); } else { cstmt.setShort(parameterName, x); } return this; } /** * Sets the int value for the specified parameter. * * @param parameterName the name of the parameter * @param x the int value to set * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs */ public CallableQuery setInt(final String parameterName, final int x) throws SQLException { cstmt.setInt(parameterName, x); return this; } /** * Sets the int value for the specified parameter. * * @param parameterName the name of the parameter * @param x the int value to set, or {@code null} to set the parameter to SQL NULL * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs */ public CallableQuery setInt(final String parameterName, final Integer x) throws SQLException { if (x == null) { cstmt.setNull(parameterName, java.sql.Types.INTEGER); } else { cstmt.setInt(parameterName, x); } return this; } /** * Sets the long value for the specified parameter. * * @param parameterName the name of the parameter * @param x the long value to set * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs */ public CallableQuery setLong(final String parameterName, final long x) throws SQLException { cstmt.setLong(parameterName, x); return this; } /** * Sets the long value for the specified parameter. * * @param parameterName the name of the parameter * @param x the long value to set, or {@code null} to set the parameter to SQL NULL * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs */ public CallableQuery setLong(final String parameterName, final Long x) throws SQLException { if (x == null) { cstmt.setNull(parameterName, java.sql.Types.BIGINT); } else { cstmt.setLong(parameterName, x); } return this; } /** * Sets the long value for the specified parameter using a BigInteger. * * @param parameterName the name of the parameter * @param x the BigInteger value to set, or {@code null} to set the parameter to SQL NULL * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs */ public CallableQuery setLong(final String parameterName, final BigInteger x) throws SQLException { if (x == null) { cstmt.setNull(parameterName, Types.BIGINT); } else { cstmt.setLong(parameterName, x.longValueExact()); } return this; } /** * Sets the float value for the specified parameter. * * @param parameterName the name of the parameter * @param x the float value to set * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs */ public CallableQuery setFloat(final String parameterName, final float x) throws SQLException { cstmt.setFloat(parameterName, x); return this; } /** * Sets the float value for the specified parameter. * * @param parameterName the name of the parameter * @param x the float value to set, or {@code null} to set the parameter to SQL NULL * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs */ public CallableQuery setFloat(final String parameterName, final Float x) throws SQLException { if (x == null) { cstmt.setNull(parameterName, java.sql.Types.FLOAT); } else { cstmt.setFloat(parameterName, x); } return this; } /** * Sets the double value for the specified parameter. * * @param parameterName the name of the parameter * @param x the double value to set * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs */ public CallableQuery setDouble(final String parameterName, final double x) throws SQLException { cstmt.setDouble(parameterName, x); return this; } /** * Sets the double value for the specified parameter. * * @param parameterName the name of the parameter * @param x the double value to set, or {@code null} to set the parameter to SQL NULL * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs */ public CallableQuery setDouble(final String parameterName, final Double x) throws SQLException { if (x == null) { cstmt.setNull(parameterName, java.sql.Types.DOUBLE); } else { cstmt.setDouble(parameterName, x); } return this; } /** * Sets the BigDecimal value for the specified parameter. * * @param parameterName the name of the parameter * @param x the BigDecimal value to set * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs */ public CallableQuery setBigDecimal(final String parameterName, final BigDecimal x) throws SQLException { cstmt.setBigDecimal(parameterName, x); return this; } /** * Sets the BigDecimal value for the specified parameter using a BigInteger. * * @param parameterName the name of the parameter * @param x the BigInteger value to set, or {@code null} to set the parameter to SQL NULL * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs */ public CallableQuery setBigDecimal(final String parameterName, final BigInteger x) throws SQLException { if (x == null) { cstmt.setNull(parameterName, Types.DECIMAL); } else { cstmt.setBigDecimal(parameterName, new BigDecimal(x)); } return this; } /** * Sets the string value for the specified parameter using a BigInteger. * * @param parameterName the name of the parameter * @param x the BigInteger value to set, or {@code null} to set the parameter to SQL NULL * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs * @see #setString(String, BigInteger) * @see #setBigDecimal(String, BigInteger) * @see #setLong(String, BigInteger) */ @Beta public CallableQuery 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 CallableQuery setString(final String parameterName, final String x) throws SQLException { cstmt.setString(parameterName, x); return this; } /** * Sets the string. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public CallableQuery setString(final String parameterName, final CharSequence x) throws SQLException { return setString(parameterName, x == null ? null : x.toString()); } /** * * * @param parameterName * @param x * @return * @throws SQLException */ public CallableQuery setString(final String parameterName, final char x) throws SQLException { return setString(parameterName, String.valueOf(x)); } /** * * * @param parameterName * @param x * @return * @throws SQLException */ public CallableQuery setString(final String parameterName, final Character x) throws SQLException { return setString(parameterName, x == null ? (String) null : x.toString()); //NOSONAR } /** * Sets the string. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public CallableQuery setString(final String parameterName, final BigInteger x) throws SQLException { if (x == null) { cstmt.setNull(parameterName, Types.VARCHAR); } else { cstmt.setString(parameterName, x.toString(10)); } return this; } /** * Sets the string. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public CallableQuery setNString(final String parameterName, final String x) throws SQLException { cstmt.setNString(parameterName, x); return this; } /** * Sets the date. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public CallableQuery setDate(final String parameterName, final java.sql.Date x) throws SQLException { cstmt.setDate(parameterName, x); return this; } /** * Sets the date. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public CallableQuery setDate(final String parameterName, final java.util.Date x) throws SQLException { cstmt.setDate(parameterName, x == null ? null : x instanceof java.sql.Date ? (java.sql.Date) x : new java.sql.Date(x.getTime())); return this; } /** * Sets the date value for the specified parameter using a LocalDate. * * @param parameterName the name of the parameter * @param x the LocalDate value to set, or {@code null} to set the parameter to SQL NULL * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs */ public CallableQuery setDate(final String parameterName, final LocalDate x) throws SQLException { setDate(parameterName, x == null ? null : java.sql.Date.valueOf(x)); return this; } /** * Sets the time. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public CallableQuery setTime(final String parameterName, final java.sql.Time x) throws SQLException { cstmt.setTime(parameterName, x); return this; } /** * Sets the time. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public CallableQuery setTime(final String parameterName, final java.util.Date x) throws SQLException { cstmt.setTime(parameterName, x == null ? null : x instanceof java.sql.Time ? (java.sql.Time) x : new java.sql.Time(x.getTime())); return this; } /** * Sets the time value for the specified parameter using a LocalTime. * * @param parameterName the name of the parameter * @param x the LocalTime value to set, or {@code null} to set the parameter to SQL NULL * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs */ public CallableQuery setTime(final String parameterName, final LocalTime x) throws SQLException { setTime(parameterName, x == null ? null : java.sql.Time.valueOf(x)); return this; } /** * Sets the timestamp. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public CallableQuery setTimestamp(final String parameterName, final java.sql.Timestamp x) throws SQLException { cstmt.setTimestamp(parameterName, x); return this; } /** * Sets the timestamp. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public CallableQuery setTimestamp(final String parameterName, final java.util.Date x) throws SQLException { cstmt.setTimestamp(parameterName, x == null ? null : x instanceof java.sql.Timestamp ? (java.sql.Timestamp) x : new java.sql.Timestamp(x.getTime())); return this; } /** * Sets the timestamp value for the specified parameter using a LocalDateTime. * * @param parameterName the name of the parameter * @param x the LocalDateTime value to set, or {@code null} to set the parameter to SQL NULL * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs */ public CallableQuery setTimestamp(final String parameterName, final LocalDateTime x) throws SQLException { setTimestamp(parameterName, x == null ? null : Timestamp.valueOf(x)); return this; } /** * Sets the timestamp value for the specified parameter using a ZonedDateTime. * * @param parameterName the name of the parameter * @param x the ZonedDateTime value to set, or {@code null} to set the parameter to SQL NULL * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs */ public CallableQuery setTimestamp(final String parameterName, final ZonedDateTime x) throws SQLException { setTimestamp(parameterName, x == null ? null : Timestamp.from(x.toInstant())); return this; } /** * Sets the timestamp value for the specified parameter using an OffsetDateTime. * * @param parameterName the name of the parameter * @param x the OffsetDateTime value to set, or {@code null} to set the parameter to SQL NULL * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs */ public CallableQuery setTimestamp(final String parameterName, final OffsetDateTime x) throws SQLException { setTimestamp(parameterName, x == null ? null : Timestamp.from(x.toInstant())); return this; } /** * Sets the timestamp value for the specified parameter using an Instant. * * @param parameterName the name of the parameter * @param x the Instant value to set, or {@code null} to set the parameter to SQL NULL * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs */ public CallableQuery setTimestamp(final String parameterName, final Instant x) throws SQLException { setTimestamp(parameterName, x == null ? null : Timestamp.from(x)); return this; } /** * Sets the bytes. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public CallableQuery setBytes(final String parameterName, final byte[] x) throws SQLException { cstmt.setBytes(parameterName, x); return this; } /** * Sets the ascii stream. * * @param parameterName * @param inputStream * @return * @throws SQLException the SQL exception */ public CallableQuery setAsciiStream(final String parameterName, final InputStream inputStream) throws SQLException { cstmt.setAsciiStream(parameterName, inputStream); return this; } /** * Sets the ascii stream. * * @param parameterName * @param inputStream * @param length * @return * @throws SQLException the SQL exception */ public CallableQuery setAsciiStream(final String parameterName, final InputStream inputStream, final long length) throws SQLException { cstmt.setAsciiStream(parameterName, inputStream, length); return this; } /** * Sets the binary stream. * * @param parameterName * @param inputStream * @return * @throws SQLException the SQL exception */ public CallableQuery setBinaryStream(final String parameterName, final InputStream inputStream) throws SQLException { cstmt.setBinaryStream(parameterName, inputStream); return this; } /** * Sets the binary stream. * * @param parameterName * @param inputStream * @param length * @return * @throws SQLException the SQL exception */ public CallableQuery setBinaryStream(final String parameterName, final InputStream inputStream, final long length) throws SQLException { cstmt.setBinaryStream(parameterName, inputStream, length); return this; } /** * Sets the character stream. * * @param parameterName * @param reader * @return * @throws SQLException the SQL exception */ public CallableQuery setCharacterStream(final String parameterName, final Reader reader) throws SQLException { cstmt.setCharacterStream(parameterName, reader); return this; } /** * Sets the character stream. * * @param parameterName * @param reader * @param length * @return * @throws SQLException the SQL exception */ public CallableQuery setCharacterStream(final String parameterName, final Reader reader, final long length) throws SQLException { cstmt.setCharacterStream(parameterName, reader, length); return this; } /** * Sets the N character stream. * * @param parameterName * @param reader * @return * @throws SQLException the SQL exception */ public CallableQuery setNCharacterStream(final String parameterName, final Reader reader) throws SQLException { cstmt.setNCharacterStream(parameterName, reader); return this; } /** * Sets the N character stream. * * @param parameterName * @param reader * @param length * @return * @throws SQLException the SQL exception */ public CallableQuery setNCharacterStream(final String parameterName, final Reader reader, final long length) throws SQLException { cstmt.setNCharacterStream(parameterName, reader, length); return this; } /** * Sets the Blob. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public CallableQuery setBlob(final String parameterName, final java.sql.Blob x) throws SQLException { cstmt.setBlob(parameterName, x); return this; } /** * Sets the Blob. * * @param parameterName * @param inputStream * @return * @throws SQLException the SQL exception */ public CallableQuery setBlob(final String parameterName, final InputStream inputStream) throws SQLException { cstmt.setBlob(parameterName, inputStream); return this; } /** * Sets the Blob. * * @param parameterName * @param inputStream * @param length * @return * @throws SQLException the SQL exception */ public CallableQuery setBlob(final String parameterName, final InputStream inputStream, final long length) throws SQLException { cstmt.setBlob(parameterName, inputStream, length); return this; } /** * Sets the Clob. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public CallableQuery setClob(final String parameterName, final java.sql.Clob x) throws SQLException { cstmt.setClob(parameterName, x); return this; } /** * Sets the Clob. * * @param parameterName * @param reader * @return * @throws SQLException the SQL exception */ public CallableQuery setClob(final String parameterName, final Reader reader) throws SQLException { cstmt.setClob(parameterName, reader); return this; } /** * Sets the Clob. * * @param parameterName * @param reader * @param length * @return * @throws SQLException the SQL exception */ public CallableQuery setClob(final String parameterName, final Reader reader, final long length) throws SQLException { cstmt.setClob(parameterName, reader, length); return this; } /** * Sets the NClob. * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public CallableQuery setNClob(final String parameterName, final java.sql.NClob x) throws SQLException { cstmt.setNClob(parameterName, x); return this; } /** * Sets the NClob. * * @param parameterName * @param reader * @return * @throws SQLException the SQL exception */ public CallableQuery setNClob(final String parameterName, final Reader reader) throws SQLException { cstmt.setNClob(parameterName, reader); return this; } /** * Sets the NClob. * * @param parameterName * @param reader * @param length * @return * @throws SQLException the SQL exception */ public CallableQuery setNClob(final String parameterName, final Reader reader, final long length) throws SQLException { cstmt.setNClob(parameterName, reader, length); return this; } /** * * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public CallableQuery setURL(final String parameterName, final URL x) throws SQLException { cstmt.setURL(parameterName, x); return this; } /** * * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public CallableQuery setSQLXML(final String parameterName, final java.sql.SQLXML x) throws SQLException { cstmt.setSQLXML(parameterName, x); return this; } /** * * * @param parameterName * @param x * @return * @throws SQLException the SQL exception */ public CallableQuery setRowId(final String parameterName, final java.sql.RowId x) throws SQLException { cstmt.setRowId(parameterName, x); return this; } /** * Sets the object value for the specified parameter. * * @param parameterName the name of the parameter * @param x the object value to set * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs */ public CallableQuery setObject(final String parameterName, final Object x) throws SQLException { if (x == null) { cstmt.setObject(parameterName, x); } else { N.typeOf(x.getClass()).set(cstmt, parameterName, x); } return this; } /** * Sets the object value for the specified parameter. * * @param parameterName the name of the parameter * @param x the object value to set * @param sqlType the SQL type code defined in {@link java.sql.Types} * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs * @see java.sql.Types */ public CallableQuery setObject(final String parameterName, final Object x, final int sqlType) throws SQLException { cstmt.setObject(parameterName, x, sqlType); return this; } /** * Sets the object value for the specified parameter. * * @param parameterName the name of the parameter * @param x the object value to set * @param sqlType the SQL type code defined in {@link java.sql.Types} * @param scaleOrLength the number of digits after the decimal point for numeric types, or the length for other types * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs * @see java.sql.Types */ public CallableQuery setObject(final String parameterName, final Object x, final int sqlType, final int scaleOrLength) throws SQLException { cstmt.setObject(parameterName, x, sqlType, scaleOrLength); return this; } /** * Sets the parameters for the CallableQuery. * * @param parameters a map containing parameter names and their corresponding values * @return the current instance of {@code CallableQuery} * @throws IllegalArgumentException if the parameters map is null * @throws SQLException if a database access error occurs */ public CallableQuery setParameters(final Map parameters) throws IllegalArgumentException, SQLException { checkArgNotNull(parameters, s.parameters); for (final Map.Entry entry : parameters.entrySet()) { setObject(entry.getKey(), entry.getValue()); } return this; } /** * Sets the parameters for the CallableQuery using the specified entity and parameter names. * * @param entity the entity object containing the parameters * @param parameterNames a collection of parameter names to be set * @return the current instance of {@code NamedQuery} * @throws IllegalArgumentException if the entity or parameter names are null * @throws SQLException if a database access error occurs * @see ClassUtil#getPropNameList(Class) * @see ClassUtil#getPropNames(Class, Collection) * @see JdbcUtil#getNamedParameters(String) */ public CallableQuery setParameters(final Object entity, final List parameterNames) throws IllegalArgumentException, SQLException { checkArgNotNull(entity, s.entity); checkArgNotNull(parameterNames, s.parameterNames); final Class cls = entity.getClass(); final BeanInfo entityInfo = ParserUtil.getBeanInfo(cls); PropInfo propInfo = null; for (final String parameterName : parameterNames) { propInfo = entityInfo.getPropInfo(parameterName); propInfo.dbType.set(cstmt, parameterName, propInfo.getPropValue(entity)); } return this; } /** * Registers the specified parameter to be an OUT parameter. * * @param parameterIndex the index of the parameter (starts from 1, not 0) * @param sqlType the SQL type code defined in {@link java.sql.Types} * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs * @see java.sql.CallableStatement#registerOutParameter(int, int) * @see java.sql.Types */ public CallableQuery registerOutParameter(final int parameterIndex, final int sqlType) throws SQLException { cstmt.registerOutParameter(parameterIndex, sqlType); addOutParameters(new Jdbc.OutParam(parameterIndex, null, sqlType, null, -1)); return this; } /** * Registers the specified parameter to be an OUT parameter with a specified scale. * * @param parameterIndex the index of the parameter (starts from 1, not 0) * @param sqlType the SQL type code defined in {@link java.sql.Types} * @param scale the number of digits to the right of the decimal point * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs * @see java.sql.CallableStatement#registerOutParameter(int, int, int * @see java.sql.Types */ public CallableQuery registerOutParameter(final int parameterIndex, final int sqlType, final int scale) throws SQLException { cstmt.registerOutParameter(parameterIndex, sqlType, scale); addOutParameters(new Jdbc.OutParam(parameterIndex, null, sqlType, null, scale)); return this; } /** * Registers the specified parameter to be an OUT parameter with a specified type name. * * @param parameterIndex the index of the parameter (starts from 1, not 0) * @param sqlType the SQL type code defined in {@link java.sql.Types} * @param typeName the SQL type name * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs * @see java.sql.CallableStatement#registerOutParameter(int, int, String) * @see java.sql.Types */ public CallableQuery registerOutParameter(final int parameterIndex, final int sqlType, final String typeName) throws SQLException { cstmt.registerOutParameter(parameterIndex, sqlType, typeName); addOutParameters(new Jdbc.OutParam(parameterIndex, null, sqlType, typeName, -1)); return this; } /** * Registers the specified parameter to be an OUT parameter. * * @param parameterName the name of the parameter * @param sqlType the SQL type code defined in {@link java.sql.Types} * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs * @see java.sql.CallableStatement#registerOutParameter(String, int) * @see java.sql.Types */ public CallableQuery registerOutParameter(final String parameterName, final int sqlType) throws SQLException { cstmt.registerOutParameter(parameterName, sqlType); addOutParameters(new Jdbc.OutParam(-1, parameterName, sqlType, null, -1)); return this; } /** * Registers the specified parameter to be an OUT parameter with a specified scale. * * @param parameterName the name of the parameter * @param sqlType the SQL type code defined in {@link java.sql.Types} * @param scale the number of digits to the right of the decimal point * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs * @see java.sql.CallableStatement#registerOutParameter(String, int, int) * @see java.sql.Types */ public CallableQuery registerOutParameter(final String parameterName, final int sqlType, final int scale) throws SQLException { cstmt.registerOutParameter(parameterName, sqlType, scale); addOutParameters(new Jdbc.OutParam(-1, parameterName, sqlType, null, scale)); return this; } /** * Registers the specified parameter to be an OUT parameter with a specified type name. * * @param parameterName the name of the parameter * @param sqlType the SQL type code defined in {@link java.sql.Types} * @param typeName the SQL type name * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs * @see java.sql.CallableStatement#registerOutParameter(String, int, String) * @see java.sql.Types */ public CallableQuery registerOutParameter(final String parameterName, final int sqlType, final String typeName) throws SQLException { cstmt.registerOutParameter(parameterName, sqlType, typeName); addOutParameters(new Jdbc.OutParam(-1, parameterName, sqlType, typeName, -1)); return this; } /** * Registers the specified parameter to be an OUT parameter. * * @param parameterIndex the index of the parameter (starts from 1, not 0) * @param sqlType the SQL type code defined in {@link java.sql.SQLType} * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs * @see java.sql.CallableStatement#registerOutParameter(int, java.sql.SQLType) */ public CallableQuery registerOutParameter(final int parameterIndex, final SQLType sqlType) throws SQLException { cstmt.registerOutParameter(parameterIndex, sqlType); addOutParameters(new Jdbc.OutParam(parameterIndex, null, sqlType.getVendorTypeNumber(), null, -1)); return this; } /** * Registers the specified parameter to be an OUT parameter with a specified scale. * * @param parameterIndex the index of the parameter (starts from 1, not 0) * @param sqlType the SQL type code defined in {@link java.sql.SQLType} * @param scale the number of digits to the right of the decimal point * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs * @see java.sql.CallableStatement#registerOutParameter(int, java.sql.SQLType, int) */ public CallableQuery registerOutParameter(final int parameterIndex, final SQLType sqlType, final int scale) throws SQLException { cstmt.registerOutParameter(parameterIndex, sqlType, scale); addOutParameters(new Jdbc.OutParam(parameterIndex, null, sqlType.getVendorTypeNumber(), null, scale)); return this; } /** * Registers the specified parameter to be an OUT parameter with a specified type name. * * @param parameterIndex the index of the parameter (starts from 1, not 0) * @param sqlType the SQL type code defined in {@link java.sql.SQLType} * @param typeName the SQL type name * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs * @see java.sql.CallableStatement#registerOutParameter(int, java.sql.SQLType, String) */ public CallableQuery registerOutParameter(final int parameterIndex, final SQLType sqlType, final String typeName) throws SQLException { cstmt.registerOutParameter(parameterIndex, sqlType, typeName); addOutParameters(new Jdbc.OutParam(parameterIndex, null, sqlType.getVendorTypeNumber(), typeName, -1)); return this; } /** * Registers the specified parameter to be an OUT parameter. * * @param parameterName the name of the parameter * @param sqlType the SQL type code defined in {@link java.sql.SQLType} * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs * @see java.sql.CallableStatement#registerOutParameter(String, java.sql.SQLType) */ public CallableQuery registerOutParameter(final String parameterName, final SQLType sqlType) throws SQLException { cstmt.registerOutParameter(parameterName, sqlType); addOutParameters(new Jdbc.OutParam(-1, parameterName, sqlType.getVendorTypeNumber(), null, -1)); return this; } /** * Registers the specified parameter to be an OUT parameter with a specified scale. * * @param parameterName the name of the parameter * @param sqlType the SQL type code defined in {@link java.sql.SQLType} * @param scale the number of digits to the right of the decimal point * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs * @see java.sql.CallableStatement#registerOutParameter(String, java.sql.SQLType, int) */ public CallableQuery registerOutParameter(final String parameterName, final SQLType sqlType, final int scale) throws SQLException { cstmt.registerOutParameter(parameterName, sqlType, scale); addOutParameters(new Jdbc.OutParam(-1, parameterName, sqlType.getVendorTypeNumber(), null, scale)); return this; } /** * Registers the specified parameter to be an OUT parameter with a specified type name. * * @param parameterName the name of the parameter * @param sqlType the SQL type code defined in {@link java.sql.SQLType} * @param typeName the SQL type name * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs * @see java.sql.CallableStatement#registerOutParameter(String, java.sql.SQLType, String) */ public CallableQuery registerOutParameter(final String parameterName, final SQLType sqlType, final String typeName) throws SQLException { cstmt.registerOutParameter(parameterName, sqlType, typeName); addOutParameters(new Jdbc.OutParam(-1, parameterName, sqlType.getVendorTypeNumber(), typeName, -1)); return this; } /** * Registers multiple OUT parameters using the specified ParametersSetter. * * @param register the ParametersSetter to register the OUT parameters * @return the current instance of {@code CallableQuery} * @throws IllegalArgumentException if the register is null * @throws SQLException if a database access error occurs */ public CallableQuery registerOutParameters(final Jdbc.ParametersSetter register) throws IllegalArgumentException, SQLException { checkArgNotNull(register, s.register); boolean noException = false; try { register.accept(this); noException = true; } finally { if (!noException) { close(); } } return this; } /** * Registers multiple OUT parameters using the specified BiParametersSetter. * * @param the type of the parameter * @param parameter the parameter to be used in the BiParametersSetter * @param register the BiParametersSetter to register the OUT parameters * @return the current instance of {@code CallableQuery} * @throws SQLException if a database access error occurs */ public CallableQuery registerOutParameters(final T parameter, final Jdbc.BiParametersSetter register) throws SQLException { checkArgNotNull(register, s.register); boolean noException = false; try { register.accept(this, parameter); noException = true; } finally { if (!noException) { close(); } } return this; } private void addOutParameters(final Jdbc.OutParam outParameter) { if (outParams == null) { outParams = new ArrayList<>(); } outParams.add(outParameter); } @Override protected ResultSet executeQuery() throws SQLException { if (!isFetchDirectionSet) { cstmt.setFetchDirection(ResultSet.FETCH_FORWARD); } boolean ret = JdbcUtil.execute(cstmt); int updateCount = cstmt.getUpdateCount(); while (ret || updateCount != -1) { if (ret) { return cstmt.getResultSet(); } else { ret = cstmt.getMoreResults(); updateCount = cstmt.getUpdateCount(); } } return null; } /** * Executes the CallableStatement and applies the provided function to the result. * * @param the type of the result * @param getter the function to apply to the CallableStatement * @return the result of applying the function to the CallableStatement * @throws SQLException if a database access error occurs * @see JdbcUtil#getOutParameters(CallableStatement, List) * @see JdbcUtil#streamAllResultSets(Statement, Jdbc.ResultExtractor) * @see JdbcUtil#streamAllResultSets(Statement, Jdbc.BiResultExtractor) */ @Override public R executeThenApply(final Throwables.Function getter) throws SQLException { //NOSONAR return super.executeThenApply(getter); } /** * Executes the CallableStatement and applies the provided BiFunction to the result. * * @param the type of the result * @param getter the BiFunction to apply to the CallableStatement. The first parameter indicates if the first result is a {@code ResultSet} object, * the second parameter is the executed {@code CallableStatement}. * @return the result of applying the BiFunction to the CallableStatement * @throws SQLException if a database access error occurs * @see JdbcUtil#getOutParameters(CallableStatement, List) * @see JdbcUtil#streamAllResultSets(Statement, Jdbc.ResultExtractor) * @see JdbcUtil#streamAllResultSets(Statement, Jdbc.BiResultExtractor) */ @Override public R executeThenApply(final Throwables.BiFunction getter) throws SQLException { //NOSONAR return super.executeThenApply(getter); } /** * Executes the CallableStatement and applies the provided TriFunction to the result. * * @param the type of the result * @param getter the TriFunction to apply to the CallableStatement. The first parameter indicates if the first result is a {@code ResultSet} object, * the second parameter is the list of OUT parameters, and the third parameter is the executed {@code CallableStatement}. * @return the result of applying the TriFunction to the CallableStatement * @throws SQLException if a database access error occurs * @see JdbcUtil#getOutParameters(CallableStatement, List) * @see JdbcUtil#streamAllResultSets(Statement, Jdbc.ResultExtractor) * @see JdbcUtil#streamAllResultSets(Statement, Jdbc.BiResultExtractor) */ public R executeThenApply(final Throwables.TriFunction, ? super CallableStatement, ? extends R, SQLException> getter) throws SQLException { checkArgNotNull(getter, s.getter); assertNotClosed(); try { final boolean isFirstResultSet = JdbcUtil.execute(cstmt); outParams = outParams == null ? N.emptyList() : outParams; return getter.apply(isFirstResultSet, outParams, cstmt); } finally { closeAfterExecutionIfAllowed(); } } /** * Executes the CallableStatement and applies the provided consumer to the statement. * * @param consumer the consumer to apply to the CallableStatement * @throws SQLException if a database access error occurs * @see JdbcUtil#getOutParameters(CallableStatement, List) * @see JdbcUtil#streamAllResultSets(Statement, Jdbc.ResultExtractor) * @see JdbcUtil#streamAllResultSets(Statement, Jdbc.BiResultExtractor) */ @Override public void executeThenAccept(final Throwables.Consumer consumer) throws SQLException { //NOSONAR super.executeThenAccept(consumer); } /** * Executes the CallableStatement and applies the provided BiConsumer to the statement. * * @param consumer the BiConsumer to apply to the CallableStatement. The first parameter indicates if the first result is a {@code ResultSet} object, * the second parameter is the executed {@code CallableStatement}. * @throws SQLException if a database access error occurs * @see JdbcUtil#getOutParameters(CallableStatement, List) * @see JdbcUtil#streamAllResultSets(Statement, Jdbc.ResultExtractor) * @see JdbcUtil#streamAllResultSets(Statement, Jdbc.BiResultExtractor) */ @Override public void executeThenAccept(final Throwables.BiConsumer consumer) throws SQLException { //NOSONAR super.executeThenAccept(consumer); } /** * Executes the CallableStatement and applies the provided TriConsumer to the statement. * * @param consumer the TriConsumer to apply to the CallableStatement. The first parameter indicates if the first result is a {@code ResultSet} object, * the second parameter is the list of OUT parameters, and the third parameter is the executed {@code CallableStatement}. * @throws SQLException if a database access error occurs * @see JdbcUtil#getOutParameters(CallableStatement, List) * @see JdbcUtil#streamAllResultSets(Statement, Jdbc.ResultExtractor) * @see JdbcUtil#streamAllResultSets(Statement, Jdbc.BiResultExtractor) */ public void executeThenAccept(final Throwables.TriConsumer, ? super CallableStatement, SQLException> consumer) throws SQLException { checkArgNotNull(consumer, s.consumer); assertNotClosed(); try { final boolean isFirstResultSet = JdbcUtil.execute(cstmt); outParams = outParams == null ? N.emptyList() : outParams; consumer.accept(isFirstResultSet, outParams, cstmt); } finally { closeAfterExecutionIfAllowed(); } } /** * Executes the stored procedure and returns the out parameters. * * @return a list of {@code Out Parameters}. * @throws IllegalStateException if this is closed * @throws SQLException if a database access error occurs */ public Jdbc.OutParamResult executeAndGetOutParameters() throws IllegalStateException, SQLException { assertNotClosed(); try { JdbcUtil.execute(cstmt); return JdbcUtil.getOutParameters(cstmt, outParams); } finally { closeAfterExecutionIfAllowed(); } } /** * Executes the stored procedure and returns the result set and out parameters. * The result set is converted to a DataSet object. * * @return A Tuple2 object where the first element is a DataSet object that represents the result set returned by the stored procedure, * and the second element is a Jdbc.OutParamResult object that contains the out parameters returned by the stored procedure. * @throws SQLException if a database access error occurs or this method is called on a closed CallableStatement */ public Tuple2 queryAndGetOutParameters() throws SQLException { return queryAndGetOutParameters(Jdbc.ResultExtractor.TO_DATA_SET); } /** * Executes the stored procedure and returns the result set and out parameters. * The result set is converted to a type R object using the provided ResultExtractor. * * @param The type of the object that the result set will be converted to. * @param resultExtractor The ResultExtractor to use for converting the result set to an object of type R. * @return A Tuple2 object where the first element is an object of type R that represents the result set returned by the stored procedure, * and the second element is a Jdbc.OutParamResult object that contains the out parameters returned by the stored procedure. * @throws IllegalArgumentException if {@code resultExtractor} is {@code null}. * @throws IllegalStateException if this method is called on a closed CallableStatement. * @throws SQLException if a database access error occurs. */ public Tuple2 queryAndGetOutParameters(final Jdbc.ResultExtractor resultExtractor) throws IllegalArgumentException, IllegalStateException, SQLException { checkArgNotNull(resultExtractor, s.resultExtractor); assertNotClosed(); try { R result = null; final ResultSet rs = executeQuery(); if (rs != null) { result = JdbcUtil.extractAndCloseResultSet(rs, resultExtractor); } return Tuple.of(result, JdbcUtil.getOutParameters(cstmt, outParams)); } finally { closeAfterExecutionIfAllowed(); } } /** * Executes the stored procedure and returns the result set and out parameters. * The result set is converted to a type R object using the provided BiResultExtractor. * * @param The type of the object that the result set will be converted to. * @param resultExtractor The BiResultExtractor to use for converting the result set to an object of type R. * @return A Tuple2 object where the first element is an object of type R that represents the result set returned by the stored procedure, * and the second element is a Jdbc.OutParamResult object that contains the out parameters returned by the stored procedure. * @throws IllegalArgumentException if {@code resultExtractor} is {@code null}. * @throws IllegalStateException if this method is called on a closed CallableStatement. * @throws SQLException if a database access error occurs. */ public Tuple2 queryAndGetOutParameters(final Jdbc.BiResultExtractor resultExtractor) throws IllegalArgumentException, IllegalStateException, SQLException { checkArgNotNull(resultExtractor, s.resultExtractor); assertNotClosed(); try { R result = null; final ResultSet rs = executeQuery(); if (rs != null) { result = JdbcUtil.extractAndCloseResultSet(rs, resultExtractor); } return Tuple.of(result, JdbcUtil.getOutParameters(cstmt, outParams)); } finally { closeAfterExecutionIfAllowed(); } } /** * Executes the stored procedure and returns all result sets and out parameters. * Each result set is converted to a DataSet object. * * @return A Tuple2 object where the first element is a List of DataSet objects, each representing a result set returned by the stored procedure, * and the second element is a Jdbc.OutParamResult object that contains the out parameters returned by the stored procedure. * @throws SQLException if a database access error occurs or this method is called on a closed CallableStatement */ public Tuple2, Jdbc.OutParamResult> queryAllResultsetsAndGetOutParameters() throws SQLException { return queryAllResultsetsAndGetOutParameters(ResultExtractor.TO_DATA_SET); } /** * Executes the stored procedure and returns all result sets and out parameters. * Each result set is converted to a type R object using the provided ResultExtractor. * * @param The type of the object that each result set will be converted to. * @param resultExtractor The ResultExtractor to use for converting each result set to an object of type R. Don't save/return {@code ResultSet}. It will be closed after this call. * @return A Tuple2 object where the first element is a List of objects of type R, each representing a result set returned by the stored procedure, * and the second element is a Jdbc.OutParamResult object that contains the out parameters returned by the stored procedure. * @throws IllegalArgumentException if {@code resultExtractor} is {@code null}. * @throws IllegalStateException if this method is called on a closed CallableStatement. * @throws SQLException if a database access error occurs. */ public Tuple2, Jdbc.OutParamResult> queryAllResultsetsAndGetOutParameters(final Jdbc.ResultExtractor resultExtractor) throws SQLException { checkArgNotNull(resultExtractor, s.resultExtractor); assertNotClosed(); ObjIteratorEx iter = null; try { final boolean isResultSet = JdbcUtil.execute(cstmt); iter = JdbcUtil.iterateAllResultSets(cstmt, isResultSet); final List resultList = new ArrayList<>(); while (iter.hasNext()) { resultList.add(JdbcUtil.extractAndCloseResultSet(iter.next(), resultExtractor)); } return Tuple.of(resultList, JdbcUtil.getOutParameters(cstmt, outParams)); } finally { try { if (iter != null) { iter.close(); } } finally { closeAfterExecutionIfAllowed(); } } } /** * Executes the stored procedure and returns all result sets and out parameters. * Each result set is converted to a type R object using the provided BiResultExtractor. * * @param The type of the object that each result set will be converted to. * @param resultExtractor The BiResultExtractor to use for converting each result set to an object of type R. Don't save/return {@code ResultSet}. It will be closed after this call. * @return A Tuple2 object where the first element is a List of objects of type R, each representing a result set returned by the stored procedure, * and the second element is a Jdbc.OutParamResult object that contains the out parameters returned by the stored procedure. * @throws IllegalArgumentException if {@code resultExtractor} is {@code null}. * @throws IllegalStateException if this method is called on a closed CallableStatement. * @throws SQLException if a database access error occurs. */ public Tuple2, Jdbc.OutParamResult> queryAllResultsetsAndGetOutParameters(final Jdbc.BiResultExtractor resultExtractor) throws SQLException { checkArgNotNull(resultExtractor, s.resultExtractor); assertNotClosed(); ObjIteratorEx iter = null; try { final boolean isResultSet = JdbcUtil.execute(cstmt); iter = JdbcUtil.iterateAllResultSets(cstmt, isResultSet); final List resultList = new ArrayList<>(); while (iter.hasNext()) { resultList.add(JdbcUtil.extractAndCloseResultSet(iter.next(), resultExtractor)); } return Tuple.of(resultList, JdbcUtil.getOutParameters(cstmt, outParams)); } finally { try { if (iter != null) { iter.close(); } } finally { closeAfterExecutionIfAllowed(); } } } /** * Executes the stored procedure and returns the first two result sets and out parameters. * Each result set is converted to a type R1 and R2 object using the provided BiResultExtractors. * * @param The type of the object that the first result set will be converted to. * @param The type of the object that the second result set will be converted to. * @param resultExtractor1 The BiResultExtractor to use for converting the first result set to an object of type R1. * @param resultExtractor2 The BiResultExtractor to use for converting the second result set to an object of type R2. * @return A Tuple3 object where the first element is an object of type R1 that represents the first result set returned by the stored procedure, * the second element is an object of type R2 that represents the second result set returned by the stored procedure, * and the third element is a Jdbc.OutParamResult object that contains the out parameters returned by the stored procedure. * @throws IllegalArgumentException if resultExtractor1 or resultExtractor2 is {@code null}. * @throws IllegalStateException if this method is called on a closed CallableStatement. * @throws SQLException if a database access error occurs. */ @Beta public Tuple3 query2ResultsetsAndGetOutParameters(final Jdbc.BiResultExtractor resultExtractor1, final Jdbc.BiResultExtractor resultExtractor2) throws IllegalArgumentException, IllegalStateException, SQLException { checkArgNotNull(resultExtractor1, s.resultExtractor1); checkArgNotNull(resultExtractor2, s.resultExtractor2); assertNotClosed(); ObjIteratorEx iter = null; try { final boolean isResultSet = JdbcUtil.execute(cstmt); iter = JdbcUtil.iterateAllResultSets(cstmt, isResultSet); R1 result1 = null; R2 result2 = null; if (iter.hasNext()) { result1 = JdbcUtil.extractAndCloseResultSet(iter.next(), resultExtractor1); } if (iter.hasNext()) { result2 = JdbcUtil.extractAndCloseResultSet(iter.next(), resultExtractor2); } return Tuple.of(result1, result2, JdbcUtil.getOutParameters(cstmt, outParams)); } finally { try { if (iter != null) { iter.close(); } } finally { closeAfterExecutionIfAllowed(); } } } /** * Executes the stored procedure and returns the first three result sets and out parameters. * Each result set is converted to a type R1, R2, and R3 object using the provided BiResultExtractors. * * @param The type of the object that the first result set will be converted to. * @param The type of the object that the second result set will be converted to. * @param The type of the object that the third result set will be converted to. * @param resultExtractor1 The BiResultExtractor to use for converting the first result set to an object of type R1. * @param resultExtractor2 The BiResultExtractor to use for converting the second result set to an object of type R2. * @param resultExtractor3 The BiResultExtractor to use for converting the third result set to an object of type R3. * @return A Tuple4 object where the first element is an object of type R1 that represents the first result set returned by the stored procedure, * the second element is an object of type R2 that represents the second result set returned by the stored procedure, * the third element is an object of type R3 that represents the third result set returned by the stored procedure, * and the fourth element is a Jdbc.OutParamResult object that contains the out parameters returned by the stored procedure. * @throws IllegalArgumentException if resultExtractor1, resultExtractor2, or resultExtractor3 is {@code null}. * @throws IllegalStateException if this method is called on a closed CallableStatement. * @throws SQLException if a database access error occurs. */ @Beta public Tuple4 query3ResultsetsAndGetOutParameters(final Jdbc.BiResultExtractor resultExtractor1, final Jdbc.BiResultExtractor resultExtractor2, final Jdbc.BiResultExtractor resultExtractor3) throws IllegalArgumentException, IllegalStateException, SQLException { checkArgNotNull(resultExtractor1, s.resultExtractor1); checkArgNotNull(resultExtractor2, s.resultExtractor2); checkArgNotNull(resultExtractor3, s.resultExtractor3); assertNotClosed(); ObjIteratorEx iter = null; try { final boolean isResultSet = JdbcUtil.execute(cstmt); iter = JdbcUtil.iterateAllResultSets(cstmt, isResultSet); R1 result1 = null; R2 result2 = null; R3 result3 = null; if (iter.hasNext()) { result1 = JdbcUtil.extractAndCloseResultSet(iter.next(), resultExtractor1); } if (iter.hasNext()) { result2 = JdbcUtil.extractAndCloseResultSet(iter.next(), resultExtractor2); } if (iter.hasNext()) { result3 = JdbcUtil.extractAndCloseResultSet(iter.next(), resultExtractor3); } return Tuple.of(result1, result2, result3, JdbcUtil.getOutParameters(cstmt, outParams)); } finally { try { if (iter != null) { iter.close(); } } finally { closeAfterExecutionIfAllowed(); } } } /** * Executes the stored procedure and returns the result set and out parameters. * The result set is converted to a list of objects of type T using the provided target type. * * @param The type of the object that the result set will be converted to. * @param targetType The class of the type T to which the result set will be converted. * @return A Tuple2 object where the first element is a List of objects of type T, each representing a row in the result set returned by the stored procedure, * and the second element is a Jdbc.OutParamResult object that contains the out parameters returned by the stored procedure. * @throws IllegalArgumentException if targetType is {@code null}. * @throws SQLException if a database access error occurs. */ public Tuple2, Jdbc.OutParamResult> listAndGetOutParameters(final Class targetType) throws IllegalArgumentException, SQLException { checkArgNotNull(targetType, s.targetType); return listAndGetOutParameters(Jdbc.BiRowMapper.to(targetType)); } /** * Executes the stored procedure and returns the result set and out parameters. * The result set is converted to a list of objects of type T using the provided RowMapper. * * @param The type of the object that the result set will be converted to. * @param rowMapper The RowMapper to use for converting the result set to a list of objects of type T. * @return A Tuple2 object where the first element is a List of objects of type T, each representing a row in the result set returned by the stored procedure, * and the second element is a Jdbc.OutParamResult object that contains the out parameters returned by the stored procedure. * @throws IllegalArgumentException if {@code rowMapper} is {@code null}. * @throws IllegalStateException if this method is called on a closed CallableStatement. * @throws SQLException if a database access error occurs. */ public Tuple2, Jdbc.OutParamResult> listAndGetOutParameters(final Jdbc.RowMapper rowMapper) throws IllegalArgumentException, IllegalStateException, SQLException { checkArgNotNull(rowMapper, s.rowMapper); assertNotClosed(); try { final List result = new ArrayList<>(); final ResultSet rs = executeQuery(); if (rs != null) { while (rs.next()) { result.add(rowMapper.apply(rs)); } } return Tuple.of(result, JdbcUtil.getOutParameters(cstmt, outParams)); } finally { closeAfterExecutionIfAllowed(); } } /** * Executes the stored procedure and returns the result set and out parameters. * The result set is filtered using the provided RowFilter and converted to a list of objects of type T using the provided RowMapper. * * @param The type of the object that the result set will be converted to. * @param rowFilter The RowFilter to use for filtering the result set. * @param rowMapper The RowMapper to use for converting the result set to a list of objects of type T. * @return A Tuple2 object where the first element is a List of objects of type T, each representing a row in the filtered result set returned by the stored procedure, * and the second element is a Jdbc.OutParamResult object that contains the out parameters returned by the stored procedure. * @throws IllegalArgumentException if {@code rowFilter} or {@code rowMapper} is {@code null}. * @throws IllegalStateException if this method is called on a closed CallableStatement. * @throws SQLException if a database access error occurs. */ public Tuple2, Jdbc.OutParamResult> listAndGetOutParameters(final Jdbc.RowFilter rowFilter, final Jdbc.RowMapper rowMapper) throws SQLException { checkArgNotNull(rowFilter, s.rowFilter); checkArgNotNull(rowMapper, s.rowMapper); assertNotClosed(); try { final List result = new ArrayList<>(); final ResultSet rs = executeQuery(); if (rs != null) { while (rs.next()) { if (rowFilter.test(rs)) { result.add(rowMapper.apply(rs)); } } } return Tuple.of(result, JdbcUtil.getOutParameters(cstmt, outParams)); } finally { closeAfterExecutionIfAllowed(); } } /** * Executes the stored procedure and returns the result set and out parameters. * The result set is converted to a list of objects of type T using the provided BiRowMapper. * * @param The type of the object that the result set will be converted to. * @param rowMapper The BiRowMapper to use for converting the result set to a list of objects of type T. * @return A Tuple2 object where the first element is a List of objects of type T, each representing a row in the result set returned by the stored procedure, * and the second element is a Jdbc.OutParamResult object that contains the out parameters returned by the stored procedure. * @throws IllegalArgumentException if {@code rowMapper} is {@code null}. * @throws IllegalStateException if this method is called on a closed CallableStatement. * @throws SQLException if a database access error occurs. */ public Tuple2, Jdbc.OutParamResult> listAndGetOutParameters(final Jdbc.BiRowMapper rowMapper) throws IllegalArgumentException, IllegalStateException, SQLException { checkArgNotNull(rowMapper, s.rowMapper); assertNotClosed(); try { final List result = new ArrayList<>(); final ResultSet rs = executeQuery(); if (rs != null) { final List columnLabels = JdbcUtil.getColumnLabelList(rs); while (rs.next()) { result.add(rowMapper.apply(rs, columnLabels)); } } return Tuple.of(result, JdbcUtil.getOutParameters(cstmt, outParams)); } finally { closeAfterExecutionIfAllowed(); } } /** * Executes the stored procedure and returns the result set and out parameters. * The result set is filtered using the provided BiRowFilter and converted to a list of objects of type T using the provided BiRowMapper. * * @param The type of the object that the result set will be converted to. * @param rowFilter The BiRowFilter to use for filtering the result set. * @param rowMapper The BiRowMapper to use for converting the result set to a list of objects of type T. * @return A Tuple2 object where the first element is a List of objects of type T, each representing a row in the filtered result set returned by the stored procedure, * and the second element is a Jdbc.OutParamResult object that contains the out parameters returned by the stored procedure. * @throws IllegalArgumentException if {@code rowFilter} or {@code rowMapper} is {@code null}. * @throws IllegalStateException if this method is called on a closed CallableStatement. * @throws SQLException if a database access error occurs. */ public Tuple2, Jdbc.OutParamResult> listAndGetOutParameters(final Jdbc.BiRowFilter rowFilter, final Jdbc.BiRowMapper rowMapper) throws SQLException { checkArgNotNull(rowFilter, s.rowFilter); checkArgNotNull(rowMapper, s.rowMapper); assertNotClosed(); try { final List result = new ArrayList<>(); final ResultSet rs = executeQuery(); if (rs != null) { final List columnLabels = JdbcUtil.getColumnLabelList(rs); while (rs.next()) { if (rowFilter.test(rs, columnLabels)) { result.add(rowMapper.apply(rs, columnLabels)); } } } return Tuple.of(result, JdbcUtil.getOutParameters(cstmt, outParams)); } finally { closeAfterExecutionIfAllowed(); } } /** * Executes the stored procedure and returns all result sets and out parameters. * Each result set is converted to a list of objects of type T using the provided target type. * * @param The type of the object that each result set will be converted to. * @param targetType The class of the type T to which each result set will be converted. * @return A Tuple2 object where the first element is a List of Lists of objects of type T, each representing a result set returned by the stored procedure, * and the second element is a Jdbc.OutParamResult object that contains the out parameters returned by the stored procedure. * @throws IllegalArgumentException if targetType is {@code null}. * @throws IllegalStateException if this method is called on a closed CallableStatement. * @throws SQLException if a database access error occurs. */ public Tuple2>, Jdbc.OutParamResult> listAllResultsetsAndGetOutParameters(final Class targetType) throws IllegalArgumentException, IllegalStateException, SQLException { checkArgNotNull(targetType, s.targetType); assertNotClosed(); try { JdbcUtil.execute(cstmt); final List> resultList = JdbcUtil.> streamAllResultSets(cstmt, Jdbc.BiResultExtractor.toList(targetType)).toList(); return Tuple.of(resultList, JdbcUtil.getOutParameters(cstmt, outParams)); } finally { closeAfterExecutionIfAllowed(); } } /** * Executes the stored procedure and returns all result sets and out parameters. * Each result set is converted to a list of objects of type T using the provided RowMapper. * * @param The type of the object that each result set will be converted to. * @param rowMapper The RowMapper to use for converting each result set to a list of objects of type T. * @return A Tuple2 object where the first element is a List of Lists of objects of type T, each representing a result set returned by the stored procedure, * and the second element is a Jdbc.OutParamResult object that contains the out parameters returned by the stored procedure. * @throws IllegalArgumentException if {@code rowMapper} is {@code null}. * @throws IllegalStateException if this method is called on a closed CallableStatement. * @throws SQLException if a database access error occurs. */ public Tuple2>, Jdbc.OutParamResult> listAllResultsetsAndGetOutParameters(final Jdbc.RowMapper rowMapper) throws IllegalArgumentException, IllegalStateException, SQLException { checkArgNotNull(rowMapper, s.rowMapper); assertNotClosed(); try { JdbcUtil.execute(cstmt); final List> resultList = JdbcUtil.> streamAllResultSets(cstmt, Jdbc.ResultExtractor.toList(rowMapper)).toList(); return Tuple.of(resultList, JdbcUtil.getOutParameters(cstmt, outParams)); } finally { closeAfterExecutionIfAllowed(); } } /** * Executes the stored procedure and returns all result sets and out parameters. * Each result set is filtered using the provided RowFilter and converted to a list of objects of type T using the provided RowMapper. * * @param The type of the object that each result set will be converted to. * @param rowFilter The RowFilter to use for filtering each result set. * @param rowMapper The RowMapper to use for converting each result set to a list of objects of type T. * @return A Tuple2 object where the first element is a List of Lists of objects of type T, each representing a result set returned by the stored procedure, * and the second element is a Jdbc.OutParamResult object that contains the out parameters returned by the stored procedure. * @throws IllegalArgumentException if {@code rowFilter} or {@code rowMapper} is {@code null}. * @throws IllegalStateException if this method is called on a closed CallableStatement. * @throws SQLException if a database access error occurs. */ public Tuple2>, Jdbc.OutParamResult> listAllResultsetsAndGetOutParameters(final Jdbc.RowFilter rowFilter, final Jdbc.RowMapper rowMapper) throws IllegalArgumentException, IllegalStateException, SQLException { checkArgNotNull(rowFilter, s.rowFilter); checkArgNotNull(rowMapper, s.rowMapper); assertNotClosed(); try { JdbcUtil.execute(cstmt); final List> resultList = JdbcUtil.> streamAllResultSets(cstmt, Jdbc.ResultExtractor.toList(rowFilter, rowMapper)).toList(); return Tuple.of(resultList, JdbcUtil.getOutParameters(cstmt, outParams)); } finally { closeAfterExecutionIfAllowed(); } } /** * Executes the stored procedure and returns all result sets and out parameters. * Each result set is converted to a list of objects of type T using the provided BiRowMapper. * * @param The type of the object that each result set will be converted to. * @param rowMapper The BiRowMapper to use for converting each result set to a list of objects of type T. * @return A Tuple2 object where the first element is a List of Lists of objects of type T, each representing a result set returned by the stored procedure, * and the second element is a Jdbc.OutParamResult object that contains the out parameters returned by the stored procedure. * @throws IllegalArgumentException if {@code rowMapper} is {@code null}. * @throws IllegalStateException if this method is called on a closed CallableStatement. * @throws SQLException if a database access error occurs. */ public Tuple2>, Jdbc.OutParamResult> listAllResultsetsAndGetOutParameters(final Jdbc.BiRowMapper rowMapper) throws IllegalArgumentException, IllegalStateException, SQLException { checkArgNotNull(rowMapper, s.rowMapper); assertNotClosed(); try { JdbcUtil.execute(cstmt); final List> resultList = JdbcUtil.> streamAllResultSets(cstmt, Jdbc.BiResultExtractor.toList(rowMapper)).toList(); return Tuple.of(resultList, JdbcUtil.getOutParameters(cstmt, outParams)); } finally { closeAfterExecutionIfAllowed(); } } /** * Executes the stored procedure and returns all result sets and out parameters. * Each result set is filtered using the provided BiRowFilter and converted to a list of objects of type T using the provided BiRowMapper. * * @param The type of the object that each result set will be converted to. * @param rowFilter The BiRowFilter to use for filtering each result set. * @param rowMapper The BiRowMapper to use for converting each result set to a list of objects of type T. * @return A Tuple2 object where the first element is a List of Lists of objects of type T, each representing a result set returned by the stored procedure, * and the second element is a Jdbc.OutParamResult object that contains the out parameters returned by the stored procedure. * @throws IllegalArgumentException if {@code rowFilter} or {@code rowMapper} is {@code null}. * @throws IllegalStateException if this method is called on a closed CallableStatement. * @throws SQLException if a database access error occurs. */ public Tuple2>, Jdbc.OutParamResult> listAllResultsetsAndGetOutParameters(final Jdbc.BiRowFilter rowFilter, final Jdbc.BiRowMapper rowMapper) throws IllegalArgumentException, IllegalStateException, SQLException { checkArgNotNull(rowFilter, s.rowFilter); checkArgNotNull(rowMapper, s.rowMapper); assertNotClosed(); try { JdbcUtil.execute(cstmt); final List> resultList = JdbcUtil.> streamAllResultSets(cstmt, Jdbc.BiResultExtractor.toList(rowFilter, rowMapper)).toList(); return Tuple.of(resultList, JdbcUtil.getOutParameters(cstmt, outParams)); } finally { closeAfterExecutionIfAllowed(); } } /** * @see JdbcUtil#execute(PreparedStatement) * @see JdbcUtil#executeUpdate(PreparedStatement) * @see JdbcUtil#executeUpdate(PreparedStatement) * @see JdbcUtil#clearParameters(PreparedStatement) */ @Override protected void closeStatement() { try { cstmt.clearParameters(); } catch (final SQLException e) { logger.warn("failed to reset statement", e); } finally { super.closeStatement(); } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy