HHH-12997,HHH-9897 throw meaningful error for @JoinFomula with @OneToMany

This commit is contained in:
Gavin King 2024-11-23 21:12:03 +01:00
parent 8a21303789
commit 9442f4da19
1 changed files with 9 additions and 4 deletions

View File

@ -322,10 +322,15 @@ public abstract class AbstractCollectionPersister
keyColumnNames = new String[keySpan]; keyColumnNames = new String[keySpan];
keyColumnAliases = new String[keySpan]; keyColumnAliases = new String[keySpan];
int k = 0; int k = 0;
for ( Column column: collectionBootDescriptor.getKey().getColumns() ) { for ( Selectable selectable: collectionBootDescriptor.getKey().getSelectables() ) {
// NativeSQL: collect key column and auto-aliases // NativeSQL: collect key column and auto-aliases
keyColumnAliases[k] = selectable.getAlias( dialect, table );
if ( selectable instanceof Column column ) {
keyColumnNames[k] = column.getQuotedName( dialect ); keyColumnNames[k] = column.getQuotedName( dialect );
keyColumnAliases[k] = column.getAlias( dialect, table ); }
else {
throw new MappingException("Collection keys may not contain formulas: " + navigableRole.getFullPath() );
}
k++; k++;
} }
@ -374,7 +379,7 @@ public abstract class AbstractCollectionPersister
elementFormulas[j] = form.getFormula(); elementFormulas[j] = form.getFormula();
} }
else { else {
Column col = (Column) selectable; final Column col = (Column) selectable;
elementColumnNames[j] = col.getQuotedName( dialect ); elementColumnNames[j] = col.getQuotedName( dialect );
elementColumnWriters[j] = col.getWriteExpr( elementBootDescriptor.getSelectableType( factory, j ), dialect ); elementColumnWriters[j] = col.getWriteExpr( elementBootDescriptor.getSelectableType( factory, j ), dialect );
elementColumnReaders[j] = col.getReadExpr( dialect ); elementColumnReaders[j] = col.getReadExpr( dialect );