/*
* Hibernate, Relational Persistence for Idiomatic Java
*
* Copyright (c) 2008-2011, Red Hat Inc. 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 Inc.
*
* 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.action.spi;
import java.io.Serializable;
import org.hibernate.HibernateException;
import org.hibernate.engine.spi.SessionImplementor;
An operation which may be scheduled for later execution. Usually, the operation is a database
insert/update/delete, together with required second-level cache management.
Author: Gavin King, Steve Ebersole
/**
* An operation which may be scheduled for later execution. Usually, the operation is a database
* insert/update/delete, together with required second-level cache management.
*
* @author Gavin King
* @author Steve Ebersole
*/
public interface Executable {
What spaces (tables) are affected by this action?
Returns: The spaces affected by this action.
/**
* What spaces (tables) are affected by this action?
*
* @return The spaces affected by this action.
*/
public Serializable[] getPropertySpaces();
Called before executing any actions. Gives actions a chance to perform any preparation.
Throws: - HibernateException – Indicates a problem during preparation.
/**
* Called before executing any actions. Gives actions a chance to perform any preparation.
*
* @throws HibernateException Indicates a problem during preparation.
*/
public void beforeExecutions() throws HibernateException;
Execute this action.
Throws: - HibernateException – Indicates a problem during execution.
/**
* Execute this action.
*
* @throws HibernateException Indicates a problem during execution.
*/
public void execute() throws HibernateException;
Get the after-transaction-completion process, if any, for this action.
Returns: The after-transaction-completion process, or null if we have no
after-transaction-completion process
/**
* Get the after-transaction-completion process, if any, for this action.
*
* @return The after-transaction-completion process, or null if we have no
* after-transaction-completion process
*/
public AfterTransactionCompletionProcess getAfterTransactionCompletionProcess();
Get the before-transaction-completion process, if any, for this action.
Returns: The before-transaction-completion process, or null if we have no
before-transaction-completion process
/**
* Get the before-transaction-completion process, if any, for this action.
*
* @return The before-transaction-completion process, or null if we have no
* before-transaction-completion process
*/
public BeforeTransactionCompletionProcess getBeforeTransactionCompletionProcess();
Reconnect to session after deserialization
Params: - session – The session being deserialized
/**
* Reconnect to session after deserialization
*
* @param session The session being deserialized
*/
public void afterDeserialize(SessionImplementor session);
}