/*
 * Hibernate, Relational Persistence for Idiomatic Java
 *
 * Copyright (c) 2010, 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.cfg;


A set of rules for determining the physical column and table names given the information in the mapping document. May be used to implement project-scoped naming standards for database objects. #propertyToTableName(String, String) should be replaced by collectionTableName(String, String, String, String, String)
Author:Gavin King, Emmanuel Bernard
See Also:
Deprecated:A NamingStrategyDelegator should be used instead.
/** * A set of rules for determining the physical column * and table names given the information in the mapping * document. May be used to implement project-scoped * naming standards for database objects. * * #propertyToTableName(String, String) should be replaced by * {@link #collectionTableName(String,String,String,String,String)} * * @see DefaultNamingStrategy * @see ImprovedNamingStrategy * @author Gavin King * @author Emmanuel Bernard * * @deprecated A {@link org.hibernate.cfg.naming.NamingStrategyDelegator} should be used instead. */
@Deprecated public interface NamingStrategy {
Return a table name for an entity class
Params:
  • className – the fully-qualified class name
Returns:a table name
/** * Return a table name for an entity class * @param className the fully-qualified class name * @return a table name */
public String classToTableName(String className);
Return a column name for a property path expression
Params:
  • propertyName – a property path
Returns:a column name
/** * Return a column name for a property path expression * @param propertyName a property path * @return a column name */
public String propertyToColumnName(String propertyName);
Alter the table name given in the mapping document
Params:
  • tableName – a table name
Returns:a table name
/** * Alter the table name given in the mapping document * @param tableName a table name * @return a table name */
public String tableName(String tableName);
Alter the column name given in the mapping document
Params:
  • columnName – a column name
Returns:a column name
/** * Alter the column name given in the mapping document * @param columnName a column name * @return a column name */
public String columnName(String columnName);
Return a collection table name ie an association having a join table
Params:
  • ownerEntity –
  • ownerEntityTable – owner side table name
  • associatedEntity –
  • associatedEntityTable – reverse side table name if any
  • propertyName – collection role
/** * Return a collection table name ie an association having a join table * * @param ownerEntity * @param ownerEntityTable owner side table name * @param associatedEntity * @param associatedEntityTable reverse side table name if any * @param propertyName collection role */
public String collectionTableName( String ownerEntity, String ownerEntityTable, String associatedEntity, String associatedEntityTable, String propertyName );
Return the join key column name ie a FK column used in a JOINED strategy or for a secondary table
Params:
  • joinedColumn – joined column name (logical one) used to join with
  • joinedTable – joined table name (ie the referenced table) used to join with
/** * Return the join key column name ie a FK column used in a JOINED strategy or for a secondary table * * @param joinedColumn joined column name (logical one) used to join with * @param joinedTable joined table name (ie the referenced table) used to join with */
public String joinKeyColumnName(String joinedColumn, String joinedTable);
Return the foreign key column name for the given parameters
Params:
  • propertyName – the property name involved
  • propertyEntityName –
  • propertyTableName – the property table name involved (logical one)
  • referencedColumnName – the referenced column name involved (logical one)
/** * Return the foreign key column name for the given parameters * @param propertyName the property name involved * @param propertyEntityName * @param propertyTableName the property table name involved (logical one) * @param referencedColumnName the referenced column name involved (logical one) */
public String foreignKeyColumnName( String propertyName, String propertyEntityName, String propertyTableName, String referencedColumnName );
Return the logical column name used to refer to a column in the metadata (like index, unique constraints etc) A full bijection is required between logicalNames and physical ones logicalName have to be case insersitively unique for a given table
Params:
  • columnName – given column name if any
  • propertyName – property name of this column
/** * Return the logical column name used to refer to a column in the metadata * (like index, unique constraints etc) * A full bijection is required between logicalNames and physical ones * logicalName have to be case insersitively unique for a given table * * @param columnName given column name if any * @param propertyName property name of this column */
public String logicalColumnName(String columnName, String propertyName);
Returns the logical collection table name used to refer to a table in the mapping metadata
Params:
  • tableName – the metadata explicit name
  • ownerEntityTable – owner table entity table name (logical one)
  • associatedEntityTable – reverse side table name if any (logical one)
  • propertyName – collection role
/** * Returns the logical collection table name used to refer to a table in the mapping metadata * * @param tableName the metadata explicit name * @param ownerEntityTable owner table entity table name (logical one) * @param associatedEntityTable reverse side table name if any (logical one) * @param propertyName collection role */
public String logicalCollectionTableName(String tableName, String ownerEntityTable, String associatedEntityTable, String propertyName);
Returns the logical foreign key column name used to refer to this column in the mapping metadata
Params:
  • columnName – given column name in the metadata if any
  • propertyName – property name
  • referencedColumn – referenced column name (logical one) in the join
/** * Returns the logical foreign key column name used to refer to this column in the mapping metadata * * @param columnName given column name in the metadata if any * @param propertyName property name * @param referencedColumn referenced column name (logical one) in the join */
public String logicalCollectionColumnName(String columnName, String propertyName, String referencedColumn); }