Skip to content

Commit

Permalink
[OPPRO-104] Support date parsing and extract year (facebookincubator#18)
Browse files Browse the repository at this point in the history
* add date parsing

* support extract year

* support int32 return type
  • Loading branch information
rui-mo authored and zhejiangxiaomai committed Jul 12, 2022
1 parent e98595d commit f3251fa
Show file tree
Hide file tree
Showing 6 changed files with 63 additions and 7 deletions.
18 changes: 12 additions & 6 deletions velox/functions/prestosql/DateTimeFunctions.h
Original file line number Diff line number Diff line change
Expand Up @@ -136,22 +136,28 @@ struct YearFunction : public InitSessionTimezone<T>,
public TimestampWithTimezoneSupport<T> {
VELOX_DEFINE_FUNCTION_TYPES(T);

FOLLY_ALWAYS_INLINE int64_t getYear(const std::tm& time) {
FOLLY_ALWAYS_INLINE int32_t getYear(const std::tm& time) {
return 1900 + time.tm_year;
}

FOLLY_ALWAYS_INLINE void call(
int64_t& result,
template <typename TInput>
FOLLY_ALWAYS_INLINE
void call(
TInput& result,
const arg_type<Timestamp>& timestamp) {
result = getYear(getDateTime(timestamp, this->timeZone_));
}

FOLLY_ALWAYS_INLINE void call(int64_t& result, const arg_type<Date>& date) {
template <typename TInput>
FOLLY_ALWAYS_INLINE
void call(TInput& result, const arg_type<Date>& date) {
result = getYear(getDateTime(date));
}

FOLLY_ALWAYS_INLINE void call(
int64_t& result,
template <typename TInput>
FOLLY_ALWAYS_INLINE
void call(
TInput& result,
const arg_type<TimestampWithTimezone>& timestampWithTimezone) {
auto timestamp = this->toTimestamp(timestampWithTimezone);
result = getYear(getDateTime(timestamp, nullptr));
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,9 @@ void registerSimpleFunctions() {
{"to_unixtime"});
registerFunction<FromUnixtimeFunction, Timestamp, double>({"from_unixtime"});

registerFunction<YearFunction, int32_t, Timestamp>({"year"});
registerFunction<YearFunction, int32_t, Date>({"year"});
registerFunction<YearFunction, int32_t, TimestampWithTimezone>({"year"});
registerFunction<YearFunction, int64_t, Timestamp>({"year"});
registerFunction<YearFunction, int64_t, Date>({"year"});
registerFunction<YearFunction, int64_t, TimestampWithTimezone>({"year"});
Expand Down
8 changes: 7 additions & 1 deletion velox/substrait/SubstraitParser.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -65,8 +65,14 @@ std::shared_ptr<SubstraitParser::SubstraitType> SubstraitParser::parseType(
nullability = substraitType.string().nullability();
break;
}
case ::substrait::Type::KindCase::kDate: {
typeName = "DATE";
nullability = sType.date().nullability();
break;
}
default:
VELOX_NYI("Substrait parsing for type {} not supported.", typeName);
VELOX_NYI(
"Substrait parsing for type {} not supported.", sType.kind_case());
}

bool nullable;
Expand Down
34 changes: 34 additions & 0 deletions velox/substrait/SubstraitToVeloxExpr.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -73,6 +73,36 @@ SubstraitVeloxExprConverter::toIsNotNullExpr(
outputType, std::move(notParams), "not");
}

std::shared_ptr<const core::ITypedExpr>
SubstraitVeloxExprConverter::toExtractExpr(
const std::vector<std::shared_ptr<const core::ITypedExpr>>& params,
const TypePtr& outputType) {
VELOX_CHECK_EQ(params.size(), 2);
auto functionArg =
std::dynamic_pointer_cast<const core::ConstantTypedExpr>(params[0]);
if (functionArg) {
// Get the function argument.
auto variant = functionArg->value();
if (!variant.hasValue()) {
VELOX_FAIL("Value expected in variant.");
}
// The first parameter specifies extracting from which field.
// Only year is supported currently.
std::string from = variant.value<std::string>();

// The second parameter is the function parameter.
std::vector<std::shared_ptr<const core::ITypedExpr>> exprParams;
exprParams.reserve(1);
exprParams.emplace_back(params[1]);
if (from == "YEAR") {
return std::make_shared<const core::CallTypedExpr>(
outputType, std::move(exprParams), "year");
}
VELOX_NYI("Extract from {} not supported.", from);
}
VELOX_FAIL("Constant is expected to be the first parameter in extract.");
}

std::shared_ptr<const core::ITypedExpr>
SubstraitVeloxExprConverter::toVeloxExpr(
const ::substrait::Expression::ScalarFunction& substraitFunc,
Expand All @@ -87,12 +117,16 @@ SubstraitVeloxExprConverter::toVeloxExpr(
const auto& veloxType =
toVeloxType(subParser_->parseType(sFunc.output_type())->type);

if (veloxFunction == "extract") {
return toExtractExpr(params, veloxType);
}
if (veloxFunction == "alias") {
return toAliasExpr(params);
}
if (veloxFunction == "is_not_null") {
return toIsNotNullExpr(params, veloxType);
}

return std::make_shared<const core::CallTypedExpr>(
veloxType, std::move(params), veloxFunction);
}
Expand Down
5 changes: 5 additions & 0 deletions velox/substrait/SubstraitToVeloxExpr.h
Original file line number Diff line number Diff line change
Expand Up @@ -68,6 +68,11 @@ class SubstraitVeloxExprConverter {
const std::vector<std::shared_ptr<const core::ITypedExpr>>& params,
const TypePtr& outputType);

/// Create expression for extract.
std::shared_ptr<const core::ITypedExpr> toExtractExpr(
const std::vector<std::shared_ptr<const core::ITypedExpr>>& params,
const TypePtr& outputType);

/// Used to convert Substrait Literal into Velox Expression.
std::shared_ptr<const core::ConstantTypedExpr> toVeloxExpr(
const ::substrait::Expression::Literal& substraitLit);
Expand Down
2 changes: 2 additions & 0 deletions velox/substrait/TypeUtils.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,8 @@ TypePtr toVeloxType(const std::string& typeName) {
return DOUBLE();
case TypeKind::VARCHAR:
return VARCHAR();
case TypeKind::DATE:
return DATE();
default:
VELOX_NYI("Velox type conversion not supported for type {}.", typeName);
}
Expand Down

0 comments on commit f3251fa

Please sign in to comment.