package io.ebeaninternal.api;
import io.ebean.bean.EntityBean;
import io.ebeaninternal.server.persist.dml.DmlHandler;
import io.ebeaninternal.server.persist.dmlbind.Bindable;
import java.sql.SQLException;
A plan for executing bean updates for a given set of changed properties.
This is a cachable plan with the purpose of being being able to skip some
phases of the update bean processing.
The plans are cached by the BeanDescriptors.
/**
* A plan for executing bean updates for a given set of changed properties.
* <p>
* This is a cachable plan with the purpose of being being able to skip some
* phases of the update bean processing.
* </p>
* <p>
* The plans are cached by the BeanDescriptors.
* </>
*/
public interface SpiUpdatePlan {
Return true if the set clause has no columns.
Can occur when the only columns updated have a updatable=false in their
deployment.
/**
* Return true if the set clause has no columns.
* <p>
* Can occur when the only columns updated have a updatable=false in their
* deployment.
* </p>
*/
boolean isEmptySetClause();
Bind given the request and bean. The bean could be the oldValues bean
when binding a update or delete where clause with ALL concurrency mode.
/**
* Bind given the request and bean. The bean could be the oldValues bean
* when binding a update or delete where clause with ALL concurrency mode.
*/
void bindSet(DmlHandler bind, EntityBean bean) throws SQLException;
Return the time this plan was created.
/**
* Return the time this plan was created.
*/
long getTimeCreated();
Return the time this plan was last used.
/**
* Return the time this plan was last used.
*/
long getTimeLastUsed();
Return the hash key for this plan.
/**
* Return the hash key for this plan.
*/
String getKey();
Return the concurrency mode for this plan.
/**
* Return the concurrency mode for this plan.
*/
ConcurrencyMode getMode();
Return the update SQL statement.
/**
* Return the update SQL statement.
*/
String getSql();
Return the set of bindable update properties.
/**
* Return the set of bindable update properties.
*/
Bindable getSet();
}