jayzhan211 commented on code in PR #14268: URL: https://github.com/apache/datafusion/pull/14268#discussion_r1933110734
########## datafusion/expr/src/type_coercion/functions.rs: ########## @@ -584,23 +544,7 @@ fn get_valid_types( match target_type_class { TypeSignatureClass::Native(native_type) => { let target_type = native_type.native(); - if &logical_type == target_type { Review Comment: As a rule of thumb, stay consistent with either Postgres or DuckDB when using functions. Avoid overly general casting that allows any type to be cast to any other type, as this can turn invalid queries into valid ones. This makes it harder to catch errors, especially when tests don't cover all cases Based on that, 1. Cast from Binary to String 👍🏻 2. Cast from Numeric to String 👎🏻 (At least for the string functions changed in this PR) 3. Cast from Float to Integer 👎🏻 (At least not for `repeat`) -- 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 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