predicate_physical_operator.h 1.2 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 12 13 14 15 16
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. */

//
// Created by WangYunlai on 2022/6/27.
//

#pragma once

羽飞's avatar
羽飞 已提交
17 18 19
#include <memory>
#include "sql/operator/physical_operator.h"
#include "sql/expr/expression.h"
羽飞's avatar
羽飞 已提交
20 21

class FilterStmt;
羽飞's avatar
羽飞 已提交
22

23 24 25 26
/**
 * @brief 过滤/谓词物理算子
 * @ingroup PhysicalOperator
 */
羽飞's avatar
羽飞 已提交
27 28
class PredicatePhysicalOperator : public PhysicalOperator
{
羽飞's avatar
羽飞 已提交
29
public:
羽飞's avatar
羽飞 已提交
30
  PredicatePhysicalOperator(std::unique_ptr<Expression> expr);
羽飞's avatar
羽飞 已提交
31

羽飞's avatar
羽飞 已提交
32
  virtual ~PredicatePhysicalOperator() = default;
羽飞's avatar
羽飞 已提交
33

L
Longda Feng 已提交
34 35 36 37 38
  PhysicalOperatorType type() const override
  {
    return PhysicalOperatorType::PREDICATE;
  }

羽飞's avatar
羽飞 已提交
39
  RC open(Trx *trx) override;
羽飞's avatar
羽飞 已提交
40 41 42
  RC next() override;
  RC close() override;

L
Longda Feng 已提交
43 44
  Tuple *current_tuple() override;

羽飞's avatar
羽飞 已提交
45
private:
羽飞's avatar
羽飞 已提交
46
  std::unique_ptr<Expression> expression_;
羽飞's avatar
羽飞 已提交
47
};