org.hibernate.persister.entity.Lockable.java Source code

Java tutorial

Introduction

Here is the source code for org.hibernate.persister.entity.Lockable.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.persister.entity;

/**
 * Contract for things that can be locked via a {@link org.hibernate.dialect.lock.LockingStrategy}.
 * <p/>
 * Currently only the root table gets locked, except for the case of HQL and Criteria queries
 * against dialects which do not support either (1) FOR UPDATE OF or (2) support hint locking
 * (in which case *all* queried tables would be locked).
 *
 * @author Steve Ebersole
 * @since 3.2
 */
public interface Lockable extends EntityPersister {
    /**
     * Locks are always applied to the "root table".
     *
     * @return The root table name
     */
    public String getRootTableName();

    /**
     * Get the SQL alias this persister would use for the root table
     * given the passed driving alias.
     *
     * @param drivingAlias The driving alias; or the alias for the table
     * mapped by this persister in the hierarchy.
     * @return The root table alias.
     */
    public String getRootTableAlias(String drivingAlias);

    /**
     * Get the names of columns on the root table used to persist the identifier.
     *
     * @return The root table identifier column names.
     */
    public String[] getRootTableIdentifierColumnNames();

    /**
     * For versioned entities, get the name of the column (again, expected on the
     * root table) used to store the version values.
     *
     * @return The version column name.
     */
    public String getVersionColumnName();
}