connectionreleasemode.java

来自「hibernate-distribution-3.3.1.GA-dist.zip」· Java 代码 · 共 101 行

JAVA
101
字号
/* * 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 <em>must</em>	 * 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.	 * <p/>	 * 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 );	}}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?