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

org.hibernate.ConnectionReleaseMode Maven / Gradle / Ivy

There is a newer version: 7.0.0.Alpha1
Show newest version
/*
 * Hibernate, Relational Persistence for Idiomatic Java
 *
 * Copyright (c) 2008, Red Hat Middleware LLC or third-party contributors as
 * indicated by the @author tags or express copyright attribution
 * statements applied by the authors.  All third-party contributions are
 * distributed under license by Red Hat Middleware LLC.
 *
 * This copyrighted material is made available to anyone wishing to use, modify,
 * copy, or redistribute it subject to the terms and conditions of the GNU
 * Lesser General Public License, as published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
 * or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Lesser General Public License
 * for more details.
 *
 * You should have received a copy of the GNU Lesser General Public License
 * along with this distribution; if not, write to:
 * Free Software Foundation, Inc.
 * 51 Franklin Street, Fifth Floor
 * Boston, MA  02110-1301  USA
 *
 */
package org.hibernate;

import java.io.Serializable;

/**
 * Defines the various policies by which Hibernate might release its underlying
 * JDBC connection.
 *
 * @author Steve Ebersole
 */
public class ConnectionReleaseMode  implements Serializable {

	/**
	 * Indicates that JDBC connection should be aggressively released after each 
	 * SQL statement is executed. In this mode, the application must
	 * explicitly close all iterators and scrollable results. This mode may
	 * only be used with a JTA datasource.
	 */
	public static final ConnectionReleaseMode AFTER_STATEMENT = new ConnectionReleaseMode( "after_statement" );

	/**
	 * Indicates that JDBC connections should be released after each transaction 
	 * ends (works with both JTA-registered synch and HibernateTransaction API).
	 * This mode may not be used with an application server JTA datasource.
	 * 

* This is the default mode starting in 3.1; was previously {@link #ON_CLOSE}. */ public static final ConnectionReleaseMode AFTER_TRANSACTION = new ConnectionReleaseMode( "after_transaction" ); /** * Indicates that connections should only be released when the Session is explicitly closed * or disconnected; this is the legacy (Hibernate2 and pre-3.1) behavior. */ public static final ConnectionReleaseMode ON_CLOSE = new ConnectionReleaseMode( "on_close" ); private String name; private ConnectionReleaseMode(String name) { this.name = name; } /** * Override of Object.toString(). Returns the release mode name. * * @return The release mode name. */ public String toString() { return name; } /** * Determine the correct ConnectionReleaseMode instance based on the given * name. * * @param modeName The release mode name. * @return The appropriate ConnectionReleaseMode instance * @throws HibernateException Indicates the modeName param did not match any known modes. */ public static ConnectionReleaseMode parse(String modeName) throws HibernateException { if ( AFTER_STATEMENT.name.equals( modeName ) ) { return AFTER_STATEMENT; } else if ( AFTER_TRANSACTION.name.equals( modeName ) ) { return AFTER_TRANSACTION; } else if ( ON_CLOSE.name.equals( modeName ) ) { return ON_CLOSE; } throw new HibernateException( "could not determine appropriate connection release mode [" + modeName + "]" ); } private Object readResolve() { return parse( name ); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy