rewriter.h 1.5 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/29.
羽飞's avatar
羽飞 已提交
13 14
//

羽飞's avatar
羽飞 已提交
15
#pragma once
羽飞's avatar
羽飞 已提交
16

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

class LogicalOperator;

羽飞's avatar
羽飞 已提交
23 24 25 26 27 28 29 30 31 32 33
/**
 * @defgroup Rewriter 
 * @brief 根据规则对逻辑计划进行重写
 */

/**
 * @brief 根据一些规则对逻辑计划进行重写
 * @ingroup Rewriter
 * @details 当前仅实现了一两个非常简单的规则。
 * 重写包括对逻辑计划和计划中包含的表达式。
 */
羽飞's avatar
羽飞 已提交
34 35
class Rewriter 
{
L
Longda Feng 已提交
36
public:
羽飞's avatar
羽飞 已提交
37 38
  Rewriter();
  virtual ~Rewriter() = default;
L
Longda Feng 已提交
39

羽飞's avatar
羽飞 已提交
40 41 42 43 44 45 46
  /**
   * @brief 对逻辑计划进行重写
   * @details 如果重写发生,change_made为true,否则为false。
   * 通常情况下如果改写发生改变,就会继续重写,直到没有改变为止。
   * @param oper 逻辑计划
   * @param change_made 当前是否有重写发生
   */
羽飞's avatar
羽飞 已提交
47 48 49 50 51
  RC rewrite(std::unique_ptr<LogicalOperator> &oper, bool &change_made);

private:
  std::vector<std::unique_ptr<RewriteRule>> rewrite_rules_;
};