org.hibernate.ScrollMode.java Source code

Java tutorial

Introduction

Here is the source code for org.hibernate.ScrollMode.java

Source

/*
 * 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 {@link ScrollableResults}.
 *
 * @author Gavin King
 */
public enum ScrollMode {
    /**
     * 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 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 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.
     *
     * @return the JDBC result set type code
     */
    public int toResultSetType() {
        return resultSetType;
    }

    /**
     * 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;
    }

}