-
Notifications
You must be signed in to change notification settings - Fork 1.3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Move nullif
and isnan
to datafusion-functions
#9216
Conversation
@@ -83,8 +82,6 @@ pub enum BuiltinScalarFunction { | |||
Gcd, | |||
/// lcm, Least common multiple | |||
Lcm, | |||
/// isnan |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
One benefit is that the implementation of these functions are consolidated, rather than having them spread all over
use arrow::datatypes::DataType; | ||
//! "core" DataFusion functions | ||
|
||
mod nullif; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
To add new functions, we can add the appropriate module and entry in this file
signature: Signature, | ||
} | ||
|
||
/// Currently supported types by the nullif function. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this code is just moved from various other places in the codebase. There is no new logic
/// $RETURN_TYPE: the type of array to return | ||
/// $FUNC: the function to apply to each element of $ARG | ||
/// | ||
macro_rules! make_function_scalar_inputs_return_type { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is copied (with more documentation) from datafusion-physical_expr. Once we move all the functions we can remove the original copy
Ok(DataType::Boolean) | ||
} | ||
|
||
fn invoke(&self, args: &[ColumnarValue]) -> Result<ColumnarValue> { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Likewise all this code is moved from elsewhere, it is not new
@@ -58,15 +58,15 @@ use datafusion_expr::{ | |||
current_time, date_bin, date_part, date_trunc, degrees, digest, ends_with, exp, | |||
expr::{self, InList, Sort, WindowFunction}, | |||
factorial, find_in_set, flatten, floor, from_unixtime, gcd, gen_range, initcap, | |||
instr, isnan, iszero, lcm, left, levenshtein, ln, log, log10, log2, | |||
instr, iszero, lcm, left, levenshtein, ln, log, log10, log2, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
the expr_fn's are still available (via datafusion_functions exports)
SELECT nullif(1); | ||
---- | ||
DataFusion error: Failed to coerce arguments for NULLIF |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I improved the error message slightly as well
move nullif
a355d4a
to
8e5f3ad
Compare
let planner = SqlToRel::new_with_options(&context, options); | ||
let result = DFParser::parse_sql_with_dialect(sql, dialect); | ||
let mut ast = result?; | ||
planner.statement_to_plan(ast.pop_front().unwrap()) | ||
} | ||
|
||
fn make_udf(name: &'static str, args: Vec<DataType>, return_type: DataType) -> ScalarUDF { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The sql integration test needs function definitions, to resolve function names, but doesn't actually invoke them
/// $ARG: ArrayRef | ||
/// $NAME: name of the argument (for error messages) | ||
/// $ARRAY_TYPE: the type of array to cast the argument to | ||
macro_rules! downcast_arg { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I remember to move those downcast macros :)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
lgtm, thanks @alamb
Thank you @comphead 🙏 |
Which issue does this PR close?
Part of #8045
See also #9100
Rationale for this change
The high level rationale is described in #8045
In this PR I am trying to set up the pattern for how functions can be moved to the
datafusion-functions
crate so we can continue the wholesale movement.I specifically wanted
core
to unblock the movement ofarrow_cast
-- #9143 (comment) from @brayanjulsWhat changes are included in this PR?
isnan
function todatafusion-functions
crate, math_expressionsdatafusion-functions
crate, core_expressionsAre these changes tested?
Yes, covered by existing tests and new CI test
Are there any user-facing changes?
I don't think so