blob: 7ac969bf7ebc5569470c830fa3a1b858d514fa2d [file] [log] [blame]
/*******************************************************************************
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*******************************************************************************/
package org.ofbiz.entity.util;
import java.sql.ResultSet;
/**
* Contains a number of variables used to select certain advanced finding options.
*/
@SuppressWarnings("serial")
public class EntityFindOptions implements java.io.Serializable {
/** Type constant from the java.sql.ResultSet object for convenience */
public static final int TYPE_FORWARD_ONLY = ResultSet.TYPE_FORWARD_ONLY;
/** Type constant from the java.sql.ResultSet object for convenience */
public static final int TYPE_SCROLL_INSENSITIVE = ResultSet.TYPE_SCROLL_INSENSITIVE;
/** Type constant from the java.sql.ResultSet object for convenience */
public static final int TYPE_SCROLL_SENSITIVE = ResultSet.TYPE_SCROLL_SENSITIVE;
/** Concurrency constant from the java.sql.ResultSet object for convenience */
public static final int CONCUR_READ_ONLY = ResultSet.CONCUR_READ_ONLY;
/** Concurrency constant from the java.sql.ResultSet object for convenience */
public static final int CONCUR_UPDATABLE = ResultSet.CONCUR_UPDATABLE;
protected boolean specifyTypeAndConcur = true;
protected int resultSetType = TYPE_FORWARD_ONLY;
protected int resultSetConcurrency = CONCUR_READ_ONLY;
protected int fetchSize = -1;
protected int maxRows = -1;
protected boolean distinct = false;
/** LIMIT option */
protected int limit = -1;
/** OFFSET option */
protected int offset = -1;
/** Default constructor. Defaults are as follows:
* specifyTypeAndConcur = true
* resultSetType = TYPE_FORWARD_ONLY
* resultSetConcurrency = CONCUR_READ_ONLY
* distinct = false
* maxRows = 0 (all rows)
*/
public EntityFindOptions() {}
public EntityFindOptions(boolean specifyTypeAndConcur, int resultSetType, int resultSetConcurrency, int fetchSize, int maxRows, boolean distinct) {
this.specifyTypeAndConcur = specifyTypeAndConcur;
this.resultSetType = resultSetType;
this.resultSetConcurrency = resultSetConcurrency;
this.fetchSize = fetchSize;
this.maxRows = maxRows;
this.distinct = distinct;
}
public EntityFindOptions(boolean specifyTypeAndConcur, int resultSetType, int resultSetConcurrency, boolean distinct) {
this(specifyTypeAndConcur, resultSetType, resultSetConcurrency, -1, -1, distinct);
}
/** If true the following two parameters (resultSetType and resultSetConcurrency) will be used to specify
* how the results will be used; if false the default values for the JDBC driver will be used
*/
public boolean getSpecifyTypeAndConcur() {
return specifyTypeAndConcur;
}
/** If true the following two parameters (resultSetType and resultSetConcurrency) will be used to specify
* how the results will be used; if false the default values for the JDBC driver will be used
*/
public void setSpecifyTypeAndConcur(boolean specifyTypeAndConcur) {
this.specifyTypeAndConcur = specifyTypeAndConcur;
}
/** Specifies how the ResultSet will be traversed. Available values: ResultSet.TYPE_FORWARD_ONLY,
* ResultSet.TYPE_SCROLL_INSENSITIVE or ResultSet.TYPE_SCROLL_SENSITIVE. See the java.sql.ResultSet JavaDoc for
* more information. If you want it to be fast, use the common default: ResultSet.TYPE_FORWARD_ONLY.
*/
public int getResultSetType() {
return resultSetType;
}
/** Specifies how the ResultSet will be traversed. Available values: ResultSet.TYPE_FORWARD_ONLY,
* ResultSet.TYPE_SCROLL_INSENSITIVE or ResultSet.TYPE_SCROLL_SENSITIVE. See the java.sql.ResultSet JavaDoc for
* more information. If you want it to be fast, use the common default: ResultSet.TYPE_FORWARD_ONLY.
*/
public void setResultSetType(int resultSetType) {
this.resultSetType = resultSetType;
}
/** Specifies whether or not the ResultSet can be updated. Available values:
* ResultSet.CONCUR_READ_ONLY or ResultSet.CONCUR_UPDATABLE. Should pretty much always be
* ResultSet.CONCUR_READ_ONLY with the Entity Engine.
*/
public int getResultSetConcurrency() {
return resultSetConcurrency;
}
/** Specifies whether or not the ResultSet can be updated. Available values:
* ResultSet.CONCUR_READ_ONLY or ResultSet.CONCUR_UPDATABLE. Should pretty much always be
* ResultSet.CONCUR_READ_ONLY with the Entity Engine.
*/
public void setResultSetConcurrency(int resultSetConcurrency) {
this.resultSetConcurrency = resultSetConcurrency;
}
/** Specifies the fetch size for this query. -1 will fall back to datasource settings. */
public int getFetchSize() {
return fetchSize;
}
/** Specifies the fetch size for this query. -1 will fall back to datasource settings. */
public void setFetchSize(int fetchSize) {
this.fetchSize = fetchSize;
}
/** Specifies the max number of rows to return, 0 means all rows. */
public int getMaxRows() {
return maxRows;
}
/** Specifies the max number of rows to return, 0 means all rows. */
public void setMaxRows(int maxRows) {
this.maxRows = maxRows;
}
/** Specifies whether the values returned should be filtered to remove duplicate values. */
public boolean getDistinct() {
return distinct;
}
/** Specifies whether the values returned should be filtered to remove duplicate values. */
public void setDistinct(boolean distinct) {
this.distinct = distinct;
}
/** Get the LIMIT number. */
public int getLimit() {
return limit;
}
/** Specifies the LIMIT number. */
public void setLimit(int limit) {
this.limit = limit;
}
/** Get the OFFSET number. */
public int getOffset() {
return offset;
}
/** Specifies the OFFSET number. */
public void setOffset(int offset) {
this.offset = offset;
}
}