scsmithr opened a new issue, #15161:
URL: https://github.com/apache/datafusion/issues/15161

   ### Describe the bug
   
   A comparison like `column1 < '10'` (where `column1` is an int64) will cast 
`column1` to utf8 instead of casting the utf8 constant to an integer.
   
   Typically string constants in a sql query are treated as unknown, and 
preference should be on casting the "unknown" value to a target type.
   
   
   ### To Reproduce
   
   ```
   DataFusion CLI v46.0.0
   > create table t1 as (values (1), (2), (3));
   0 row(s) fetched. 
   Elapsed 0.026 seconds.
   
   > select * from t1 where column1 < '10';
   +---------+
   | column1 |
   +---------+
   | 1       |
   +---------+
   1 row(s) fetched. 
   Elapsed 0.015 seconds.
   
   > select * from t1 where column1 < 'hello';
   +---------+
   | column1 |
   +---------+
   | 1       |
   | 2       |
   | 3       |
   +---------+
   3 row(s) fetched. 
   Elapsed 0.007 seconds.
   
   > select arrow_typeof(column1) from t1 limit 1;
   +--------------------------+
   | arrow_typeof(t1.column1) |
   +--------------------------+
   | Int64                    |
   +--------------------------+
   1 row(s) fetched. 
   Elapsed 0.010 seconds.
   
   > explain select * from t1 where column1 < '10';
   +---------------+-------------------------------------------------------+
   | plan_type     | plan                                                  |
   +---------------+-------------------------------------------------------+
   | logical_plan  | Filter: CAST(t1.column1 AS Utf8) < Utf8("10")         |
   |               |   TableScan: t1 projection=[column1]                  |
   | physical_plan | CoalesceBatchesExec: target_batch_size=8192           |
   |               |   FilterExec: CAST(column1@0 AS Utf8) < 10            |
   |               |     DataSourceExec: partitions=1, partition_sizes=[1] |
   |               |                                                       |
   +---------------+-------------------------------------------------------+
   2 row(s) fetched. 
   Elapsed 0.009 seconds.
   ```
   
   ### Expected behavior
   
   `column1` not to be cast to a string.
   
   ### Additional context
   
   _No response_


-- 
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.

To unsubscribe, e-mail: github-unsubscr...@datafusion.apache.org.apache.org

For queries about this service, please contact Infrastructure at:
us...@infra.apache.org


---------------------------------------------------------------------
To unsubscribe, e-mail: github-unsubscr...@datafusion.apache.org
For additional commands, e-mail: github-h...@datafusion.apache.org

Reply via email to