From 58d11ef9b78b0098d16d85f75d8eb49d7ade0834 Mon Sep 17 00:00:00 2001 From: Luigi Dell'Aquila Date: Thu, 11 Oct 2018 14:04:10 +0200 Subject: [PATCH] Fix SQL comparison with subqueries eg. WHERE foo < (SELECT avg(foo) FROM V) Resolves: #8540 --- .../orient/core/metadata/schema/OType.java | 17 ++++++++++++++++- 1 file changed, 16 insertions(+), 1 deletion(-) diff --git a/core/src/main/java/com/orientechnologies/orient/core/metadata/schema/OType.java b/core/src/main/java/com/orientechnologies/orient/core/metadata/schema/OType.java index 97590838de0..7246e06c755 100755 --- a/core/src/main/java/com/orientechnologies/orient/core/metadata/schema/OType.java +++ b/core/src/main/java/com/orientechnologies/orient/core/metadata/schema/OType.java @@ -29,10 +29,12 @@ import com.orientechnologies.orient.core.db.record.ridbag.ORidBag; import com.orientechnologies.orient.core.id.ORID; import com.orientechnologies.orient.core.id.ORecordId; +import com.orientechnologies.orient.core.record.OElement; import com.orientechnologies.orient.core.record.impl.ODocument; import com.orientechnologies.orient.core.serialization.ODocumentSerializable; import com.orientechnologies.orient.core.serialization.OSerializableStream; import com.orientechnologies.orient.core.serialization.serializer.OStringSerializerHelper; +import com.orientechnologies.orient.core.sql.executor.OResult; import java.io.Serializable; import java.math.BigDecimal; @@ -291,7 +293,7 @@ public static boolean isSimpleType(final Object iObject) { * @return The converted value or the original if no conversion was applied */ @SuppressWarnings({ "unchecked", "rawtypes" }) - public static Object convert(final Object iValue, final Class iTargetClass) { + public static Object convert(Object iValue, final Class iTargetClass) { if (iValue == null) return null; @@ -475,6 +477,19 @@ else if (((String) iValue).equalsIgnoreCase("false")) // PASS THROUGH throw e; } catch (Exception e) { + if (iValue instanceof Collection && ((Collection) iValue).size() == 1 && !Collection.class.isAssignableFrom(iTargetClass)) { + //this must be a comparison with the result of a subquery, try to unbox the collection + return convert(((Collection) iValue).iterator().next(), iTargetClass); + } else if (iValue instanceof OResult && ((OResult) iValue).getPropertyNames().size() == 1 && !OResult.class + .isAssignableFrom(iTargetClass)) { + // try to unbox OResult with a single property, for subqueries + return convert(((OResult) iValue).getProperty(((OResult) iValue).getPropertyNames().iterator().next()), iTargetClass); + } else if (iValue instanceof OElement && ((OElement) iValue).getPropertyNames().size() == 1 && !OElement.class + .isAssignableFrom(iTargetClass)) { + // try to unbox OResult with a single property, for subqueries + return convert(((OElement) iValue).getProperty(((OElement) iValue).getPropertyNames().iterator().next()), iTargetClass); + } + OLogManager.instance().debug(OType.class, "Error in conversion of value '%s' to type '%s'", e, iValue, iTargetClass); return null; }