/*
 * Hibernate, Relational Persistence for Idiomatic Java
 *
 * License: GNU Lesser General Public License (LGPL), version 2.1 or later.
 * See the lgpl.txt file in the root directory or <http://www.gnu.org/licenses/lgpl-2.1.html>.
 */
package org.hibernate;

import java.sql.ResultSet;

Specifies the type of JDBC scrollable result set to use underneath a ScrollableResults.
Author:Gavin King
/** * Specifies the type of JDBC scrollable result set to use underneath a {@link ScrollableResults}. * * @author Gavin King */
public enum ScrollMode {
Requests a scrollable result that is only scrollable forwards.
See Also:
  • TYPE_FORWARD_ONLY.TYPE_FORWARD_ONLY
/** * Requests a scrollable result that is only scrollable forwards. * * @see java.sql.ResultSet#TYPE_FORWARD_ONLY */
FORWARD_ONLY( ResultSet.TYPE_FORWARD_ONLY ),
Requests a scrollable result which is sensitive to changes in the underlying data.
See Also:
  • TYPE_SCROLL_SENSITIVE.TYPE_SCROLL_SENSITIVE
/** * Requests a scrollable result which is sensitive to changes in the underlying data. * * @see java.sql.ResultSet#TYPE_SCROLL_SENSITIVE */
SCROLL_SENSITIVE( ResultSet.TYPE_SCROLL_SENSITIVE ),
Requests a scrollable result which is insensitive to changes in the underlying data. Note that since the Hibernate session acts as a cache, you might need to explicitly evict objects, if you need to see changes made by other transactions.
See Also:
  • TYPE_SCROLL_INSENSITIVE.TYPE_SCROLL_INSENSITIVE
/** * Requests a scrollable result which is insensitive to changes in the underlying data. * * Note that since the Hibernate session acts as a cache, you * might need to explicitly evict objects, if you need to see * changes made by other transactions. * * @see java.sql.ResultSet#TYPE_SCROLL_INSENSITIVE */
SCROLL_INSENSITIVE( ResultSet.TYPE_SCROLL_INSENSITIVE ); private final int resultSetType; private ScrollMode(int level) { this.resultSetType = level; }
Get the corresponding JDBC scroll type code constant value.
Returns:the JDBC result set type code
/** * Get the corresponding JDBC scroll type code constant value. * * @return the JDBC result set type code */
public int toResultSetType() { return resultSetType; }
Determine if this mode is "less than" the provided mode.
Params:
  • other – The provided mode
Returns:true if this mode is less than the other.
/** * Determine if {@code this} mode is "less than" the provided mode. * * @param other The provided mode * * @return {@code true} if this mode is less than the other. */
public boolean lessThan(ScrollMode other) { return this.resultSetType < other.resultSetType; } }