Class DuckDBFilterToSQL
- All Implemented Interfaces:
ExpressionVisitor,FilterVisitor
- Direct Known Subclasses:
GeoParquetFilterToSQL
This class handles conversion of GeoTools filters to DuckDB-compatible SQL spatial functions and provides locale-independent geometry literal encoding to avoid parsing issues in different system locales.
Features:
- Spatial Operations: Supports all standard spatial predicates including BBOX, Contains, Crosses, Disjoint, Equals, Intersects, Overlaps, Touches, Within, DWithin, and Beyond
- Locale Independence: Uses WKB (Well-Known Binary) encoding for geometry literals to avoid locale-specific decimal separator parsing issues (e.g., comma vs dot)
- DuckDB Compatibility: Leverages DuckDB's
ST_GeomFromHEXEWKBfunction for reliable geometry deserialization - Function Support: Extensible support for string, math, date, array, and geometry functions
Locale Handling:
Traditional WKT (Well-Known Text) geometry encoding can fail in locales that use comma as the decimal separator (e.g., Italian, German, French) because DuckDB may misinterpret coordinate separators in strings like "POLYGON ((-10 0, 0 0, ...))" where "0, 0" could be parsed as "0,0" (zero with decimal comma). This implementation avoids this issue entirely by using binary WKB encoding with hexadecimal representation.
- See Also:
-
Nested Class Summary
Nested classes/interfaces inherited from class FilterToSQL
FilterToSQL.FieldEncoder -
Field Summary
Fields inherited from class FilterToSQL
capabilities, currentDimension, currentGeometry, currentSRID, databaseSchema, encodingFunction, escapeBackslash, featureType, fieldEncoder, filterFactory, inEncodingEnabled, inline, IO_ERROR, LOGGER, out, primaryKey, sqlNameEscape -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionprotected FilterCapabilitiesSets the capabilities of this filter.protected ObjectvisitBBOX(BBOX filter, Expression leftExp, Expression rightExpt, Object extraData) protected ObjectvisitBinarySpatialOperator(BinarySpatialOperator filter, Expression leftExp, Expression rightExpt, Object extraData) Handles the more general case of two generic expressions.protected ObjectvisitBinarySpatialOperator(BinarySpatialOperator filter, PropertyName property, Literal geometry, boolean swapped, Object extraData) Handles the common case of a PropertyName,Literal geometry binary spatial operator.protected ObjectvisitDistanceBufferOperator(DistanceBufferOperator filter, Expression leftExp, Expression rightExpt, Object extraData) protected voidvisitLiteralGeometry(Literal expression) Converts a geometry literal to DuckDB SQL using locale-independent WKB encoding.protected voidMethods inherited from class FilterToSQL
cast, encode, encode, encodeBinaryComparisonOperator, encodeToString, encodeToString, escapeLiteral, escapeName, evaluateLiteral, getCapabilities, getDatabaseSchema, getDistanceInNativeUnits, getExpressionType, getFeatureType, getFunctionName, getFunctionReturnType, getParameter, getPrimaryKey, getSqlNameEscape, isBinaryExpression, isEscapeBackslash, isInEncodingEnabled, processLikeLeftOperand, setCapabilities, setDatabaseSchema, setEscapeBackslash, setFeatureType, setFieldEncoder, setInEncodingEnabled, setInline, setPrimaryKey, setSqlNameEscape, setWriter, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visit, visitBinaryComparisonOperator, visitBinarySpatialOperator, visitBinaryTemporalOperator, visitBinaryTemporalOperator, visitBinaryTemporalOperator, visitInFunction, visitLiteralTimePeriod, visitNullFilter, writeBinaryExpression, writeBinaryExpressionMember, writeLiteral
-
Constructor Details
-
DuckDBFilterToSQL
public DuckDBFilterToSQL()
-
-
Method Details
-
visitLiteralGeometry
Converts a geometry literal to DuckDB SQL using locale-independent WKB encoding.This method uses DuckDB's
ST_GeomFromHEXEWKBfunction with hexadecimal-encoded WKB (Well-Known Binary) data instead of the traditional WKT (Well-Known Text) approach. This ensures consistent behavior across different system locales that may use different decimal separators.In locales such as Italian (it_IT), German (de_DE), or French (fr_FR), the decimal separator is a comma instead of a dot. When using WKT encoding like:
DuckDB's parser may misinterpret the coordinate separator "0, 0" as a decimal number "0,0" with a decimal comma, causing parsing errors like:POLYGON ((-10 0, 0 0, 0 10, -10 10, -10 0))Invalid Input Error: Expected character: ')' at position '17' near: 'POLYGON ((-10 0, 0'
WKB Solution:Using WKB encoding completely bypasses text parsing of coordinates since the geometry is represented as binary data. The hexadecimal representation is locale-independent and works consistently across all systems.
- Overrides:
visitLiteralGeometryin classFilterToSQL- Parameters:
expression- the geometry literal expression to convert- Throws:
IOException- if there's an error writing to the output stream- See Also:
-
createFilterCapabilities
Description copied from class:FilterToSQLSets the capabilities of this filter.- Overrides:
createFilterCapabilitiesin classFilterToSQL- Returns:
- FilterCapabilities for this Filter
-
visitBinarySpatialOperator
protected Object visitBinarySpatialOperator(BinarySpatialOperator filter, PropertyName property, Literal geometry, boolean swapped, Object extraData) Description copied from class:FilterToSQLHandles the common case of a PropertyName,Literal geometry binary spatial operator.- Overrides:
visitBinarySpatialOperatorin classFilterToSQL
-
visitBinarySpatialOperator
protected Object visitBinarySpatialOperator(BinarySpatialOperator filter, Expression leftExp, Expression rightExpt, Object extraData) Description copied from class:FilterToSQLHandles the more general case of two generic expressions.The most common case is two PropertyName expressions, which happens during a spatial join.
- Overrides:
visitBinarySpatialOperatorin classFilterToSQL
-
visitBBOX
-
visitDistanceBufferOperator
protected Object visitDistanceBufferOperator(DistanceBufferOperator filter, Expression leftExp, Expression rightExpt, Object extraData) -
write
-