predicate_pushdown_rewriter.h 1.1 KB
Newer Older
羽飞's avatar
羽飞 已提交
1
/* Copyright (c) 2021 OceanBase and/or its affiliates. All rights reserved.
羽飞's avatar
羽飞 已提交
2 3 4 5 6 7 8 9 10 11
miniob is licensed under Mulan PSL v2.
You can use this software according to the terms and conditions of the Mulan PSL v2.
You may obtain a copy of Mulan PSL v2 at:
         http://license.coscl.org.cn/MulanPSL2
THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
See the Mulan PSL v2 for more details. */

//
羽飞's avatar
羽飞 已提交
12
// Created by Wangyunlai on 2022/12/30.
羽飞's avatar
羽飞 已提交
13 14
//

W
wangyunlai.wyl 已提交
15
#pragma once
羽飞's avatar
羽飞 已提交
16

羽飞's avatar
羽飞 已提交
17
#include <vector>
羽飞's avatar
羽飞 已提交
18
#include "sql/optimizer/rewrite_rule.h"
羽飞's avatar
羽飞 已提交
19

羽飞's avatar
羽飞 已提交
20
/**
羽飞's avatar
羽飞 已提交
21 22 23
 * @brief 将一些谓词表达式下推到表数据扫描中
 * @ingroup Rewriter
 * @details 这样可以提前过滤一些数据
羽飞's avatar
羽飞 已提交
24
 */
羽飞's avatar
羽飞 已提交
25 26
class PredicatePushdownRewriter : public RewriteRule 
{
W
wangyunlai.wyl 已提交
27
public:
羽飞's avatar
羽飞 已提交
28 29
  PredicatePushdownRewriter() = default;
  virtual ~PredicatePushdownRewriter() = default;
羽飞's avatar
羽飞 已提交
30

羽飞's avatar
羽飞 已提交
31
  RC rewrite(std::unique_ptr<LogicalOperator> &oper, bool &change_made) override;
羽飞's avatar
羽飞 已提交
32

羽飞's avatar
羽飞 已提交
33
private:
L
Longda Feng 已提交
34 35
  RC get_exprs_can_pushdown(
      std::unique_ptr<Expression> &expr, std::vector<std::unique_ptr<Expression>> &pushdown_exprs);
W
wangyunlai.wyl 已提交
36
};