mirror of
https://github.com/hibernate/hibernate-orm
synced 2025-02-27 14:30:16 +00:00
HHH-18218 - Improved type resolving when tuple element implements SqmExpressibleAccessor
This commit is contained in:
parent
9e13bd0c48
commit
4c8e72c5ec
@ -14,6 +14,9 @@
|
||||
import java.lang.reflect.Constructor;
|
||||
import java.util.List;
|
||||
|
||||
import org.hibernate.query.sqm.SqmExpressible;
|
||||
import org.hibernate.query.sqm.tree.SqmExpressibleAccessor;
|
||||
|
||||
/**
|
||||
* {@link RowTransformer} instantiating an arbitrary class
|
||||
*
|
||||
@ -28,7 +31,7 @@ public RowTransformerConstructorImpl(Class<T> type, TupleMetadata tupleMetadata)
|
||||
final List<TupleElement<?>> elements = tupleMetadata.getList();
|
||||
final Class<?>[] sig = new Class[elements.size()];
|
||||
for (int i = 0; i < elements.size(); i++) {
|
||||
sig[i] = elements.get(i).getJavaType();
|
||||
sig[i] = resolveElementJavaType( elements.get( i ) );
|
||||
}
|
||||
try {
|
||||
constructor = type.getDeclaredConstructor( sig );
|
||||
@ -40,6 +43,17 @@ public RowTransformerConstructorImpl(Class<T> type, TupleMetadata tupleMetadata)
|
||||
}
|
||||
}
|
||||
|
||||
private static Class<?> resolveElementJavaType(TupleElement<?> element) {
|
||||
if ( element instanceof SqmExpressibleAccessor ) {
|
||||
SqmExpressible expressible = ( (SqmExpressibleAccessor) element ).getExpressible();
|
||||
if ( expressible != null ) {
|
||||
return expressible.getExpressibleJavaType().getJavaTypeClass();
|
||||
}
|
||||
}
|
||||
|
||||
return element.getJavaType();
|
||||
}
|
||||
|
||||
@Override
|
||||
public T transformRow(Object[] row) {
|
||||
try {
|
||||
|
Loading…
x
Reference in New Issue
Block a user