From 9442f4da1961ce800bb2630e0ffef33503f8a717 Mon Sep 17 00:00:00 2001 From: Gavin King Date: Sat, 23 Nov 2024 21:12:03 +0100 Subject: [PATCH] HHH-12997,HHH-9897 throw meaningful error for @JoinFomula with @OneToMany --- .../collection/AbstractCollectionPersister.java | 13 +++++++++---- 1 file changed, 9 insertions(+), 4 deletions(-) diff --git a/hibernate-core/src/main/java/org/hibernate/persister/collection/AbstractCollectionPersister.java b/hibernate-core/src/main/java/org/hibernate/persister/collection/AbstractCollectionPersister.java index 6e7f56775d..9601fc2608 100644 --- a/hibernate-core/src/main/java/org/hibernate/persister/collection/AbstractCollectionPersister.java +++ b/hibernate-core/src/main/java/org/hibernate/persister/collection/AbstractCollectionPersister.java @@ -322,10 +322,15 @@ public abstract class AbstractCollectionPersister keyColumnNames = new String[keySpan]; keyColumnAliases = new String[keySpan]; int k = 0; - for ( Column column: collectionBootDescriptor.getKey().getColumns() ) { + for ( Selectable selectable: collectionBootDescriptor.getKey().getSelectables() ) { // NativeSQL: collect key column and auto-aliases - keyColumnNames[k] = column.getQuotedName( dialect ); - keyColumnAliases[k] = column.getAlias( dialect, table ); + keyColumnAliases[k] = selectable.getAlias( dialect, table ); + if ( selectable instanceof Column column ) { + keyColumnNames[k] = column.getQuotedName( dialect ); + } + else { + throw new MappingException("Collection keys may not contain formulas: " + navigableRole.getFullPath() ); + } k++; } @@ -374,7 +379,7 @@ public abstract class AbstractCollectionPersister elementFormulas[j] = form.getFormula(); } else { - Column col = (Column) selectable; + final Column col = (Column) selectable; elementColumnNames[j] = col.getQuotedName( dialect ); elementColumnWriters[j] = col.getWriteExpr( elementBootDescriptor.getSelectableType( factory, j ), dialect ); elementColumnReaders[j] = col.getReadExpr( dialect );