patch 4.0

This commit is contained in:
wangzelin.wzl
2022-10-24 10:34:53 +08:00
parent 4ad6e00ec3
commit 93a1074b0c
10533 changed files with 2588271 additions and 2299373 deletions

View File

@ -12,7 +12,7 @@
#define USING_LOG_PREFIX SQL_ENG
#include <string.h>
#include "sql/parser/ob_item_type.h"
#include "objit/common/ob_item_type.h"
#include "sql/engine/expr/ob_expr_lnnvl.h"
#include "share/object/ob_obj_cast.h"
//#include "sql/engine/expr/ob_expr_promotion_util.h"
@ -20,38 +20,24 @@
using namespace oceanbase::common;
using namespace oceanbase::sql;
namespace oceanbase {
namespace sql {}
} // namespace oceanbase
ObExprFuncLnnvl::ObExprFuncLnnvl(ObIAllocator& alloc)
: ObFuncExprOperator(alloc, T_FUN_SYS_LNNVL, N_LNNVL, 1, NOT_ROW_DIMENSION)
{}
ObExprFuncLnnvl::~ObExprFuncLnnvl()
{}
int ObExprFuncLnnvl::calc_result1(ObObj& result, const ObObj& input, ObExprCtx& expr_ctx) const
namespace oceanbase
{
int ret = OB_SUCCESS;
if (OB_UNLIKELY(NULL == expr_ctx.calc_buf_)) {
_OB_LOG(WARN, "varchar buffer not init");
ret = OB_NOT_INIT;
} else if (input.is_null()) {
result.set_bool(true);
} else {
TYPE_CHECK(input, ObTinyIntType);
int8_t tinyint_val = input.get_tinyint();
if (tinyint_val == 0) {
result.set_bool(true);
} else {
result.set_bool(false);
}
}
return ret;
namespace sql
{
}
}
int ObExprFuncLnnvl::cg_expr(ObExprCGCtx&, const ObRawExpr&, ObExpr& rt_expr) const
ObExprFuncLnnvl::ObExprFuncLnnvl(ObIAllocator &alloc)
: ObFuncExprOperator(alloc, T_FUN_SYS_LNNVL, N_LNNVL, 1, NOT_ROW_DIMENSION)
{
}
ObExprFuncLnnvl::~ObExprFuncLnnvl()
{
}
int ObExprFuncLnnvl::cg_expr(ObExprCGCtx &, const ObRawExpr &, ObExpr &rt_expr) const
{
int ret = OB_SUCCESS;
CK(1 == rt_expr.arg_cnt_);
@ -59,10 +45,10 @@ int ObExprFuncLnnvl::cg_expr(ObExprCGCtx&, const ObRawExpr&, ObExpr& rt_expr) co
return ret;
}
int ObExprFuncLnnvl::eval_lnnvl(const ObExpr& expr, ObEvalCtx& ctx, ObDatum& expr_datum)
int ObExprFuncLnnvl::eval_lnnvl(const ObExpr &expr, ObEvalCtx &ctx, ObDatum &expr_datum)
{
int ret = OB_SUCCESS;
ObDatum* arg = NULL;
ObDatum *arg = NULL;
if (OB_FAIL(expr.eval_param_value(ctx, arg))) {
LOG_WARN("evaluate parameters failed", K(ret));
} else if (arg->is_null()) {