-
Notifications
You must be signed in to change notification settings - Fork 1.2k
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
feat: Add Spark json_array_length function #11946
base: main
Are you sure you want to change the base?
feat: Add Spark json_array_length function #11946
Conversation
a971121
to
a5c0d3b
Compare
✅ Deploy Preview for meta-velox canceled.
|
✅ Deploy Preview for meta-velox canceled.
|
struct JsonArrayLengthFunction { | ||
VELOX_DEFINE_FUNCTION_TYPES(T); | ||
|
||
FOLLY_ALWAYS_INLINE bool call(int32_t& len, const arg_type<Json>& json) { |
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.
Suggestion:
Change const arg_type<Json>&
to const arg_type<Varchar>&
and remove the above corresponding header.
I think JsonType is just for presto.
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.
Thanks, fixed
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.
Looks good!
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.
Thanks for your contribution!
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.
Thanks. Added some comments.
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.
Thanks for updating. Added some comments.
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.
Thanks. Added several nits on the doc.
dbd4e2f
to
19936a1
Compare
@rui-mo Can you please take a look again? |
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 compilation fails with below exception. Would you take a look? Thanks.
/__w/velox/velox/./velox/functions/Registerer.h:45:6: note: template argument deduction/substitution failed:
/__w/velox/velox/velox/functions/prestosql/benchmarks/JsonExprBenchmark.cpp:186:61: error: template argument 1 is invalid
186 | registerFunction<JsonArrayLengthFunction, int64_t, Json>(
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^
187 | {"json_array_length"});
| ~~~~~~~~~~~~~~~~~~~~~~
a256a33
to
28dbf21
Compare
@rui-mo Fixed. the fuzzer job failed seems irrelevant. |
The 'json_array_length' functions of Presto and Spark are similar, however
Presto returns int64_t, while Spark returns int32_t. In this PR, the
'JsonArrayLengthFunction' implementation is extracted to 'velox/functions/lib'
and registered with differenct return types for Presto and Spark.
Spark doc: https://spark.apache.org/docs/latest/api/sql/#json_array_length