HHH-8073 Corrected column alias creation
This commit is contained in:
parent
a7b4e9f8fd
commit
4d20fb5334
|
@ -108,33 +108,32 @@ public class Column implements Selectable, Serializable, Cloneable {
|
|||
name;
|
||||
}
|
||||
|
||||
/**
|
||||
* For any column name, generate an alias that is unique
|
||||
* to that column name, and also 10 characters or less
|
||||
* in length.
|
||||
*/
|
||||
@Override
|
||||
public String getAlias(Dialect dialect) {
|
||||
final int lastLetter = StringHelper.lastIndexOfLetter( name );
|
||||
String suffix = Integer.toString(uniqueInteger) + '_';
|
||||
|
||||
String alias = name;
|
||||
String unique = Integer.toString(uniqueInteger) + '_';
|
||||
int lastLetter = StringHelper.lastIndexOfLetter(name);
|
||||
if ( lastLetter == -1 ) {
|
||||
alias = "column";
|
||||
}
|
||||
else if ( lastLetter < name.length()-1 ) {
|
||||
else if ( name.length() > lastLetter + 1 ) {
|
||||
alias = name.substring( 0, lastLetter + 1 );
|
||||
}
|
||||
if ( alias.length() > dialect.getMaxAliasLength() ) {
|
||||
alias = alias.substring( 0, dialect.getMaxAliasLength() - unique.length() );
|
||||
|
||||
boolean useRawName = name.length() + suffix.length() <= dialect.getMaxAliasLength()
|
||||
&& !quoted && !name.toLowerCase().equals( "rowid" );
|
||||
if ( !useRawName ) {
|
||||
if ( suffix.length() >= dialect.getMaxAliasLength() ) {
|
||||
throw new MappingException( String.format(
|
||||
"Unique suffix [%s] length must be less than maximum [%d]",
|
||||
suffix, dialect.getMaxAliasLength() ) );
|
||||
}
|
||||
boolean useRawName = name.equals(alias) &&
|
||||
!quoted &&
|
||||
!name.toLowerCase().equals("rowid");
|
||||
if ( useRawName ) {
|
||||
return alias;
|
||||
if ( alias.length() + suffix.length() > dialect.getMaxAliasLength() ) {
|
||||
alias = alias.substring( 0, dialect.getMaxAliasLength() - suffix.length() );
|
||||
}
|
||||
else {
|
||||
return alias + unique;
|
||||
}
|
||||
return alias + suffix;
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
Loading…
Reference in New Issue