Files
doris/be/src/exec/schema_scanner.h
chenhao7253886 37b4cafe87 Change variable and namespace name in BE (#268)
Change 'palo' to 'doris'
2018-11-02 10:22:32 +08:00

97 lines
2.7 KiB
C++

// Licensed to the Apache Software Foundation (ASF) under one
// or more contributor license agreements. See the NOTICE file
// distributed with this work for additional information
// regarding copyright ownership. The ASF licenses this file
// to you under the Apache License, Version 2.0 (the
// "License"); you may not use this file except in compliance
// with the License. You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing,
// software distributed under the License is distributed on an
// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
// KIND, either express or implied. See the License for the
// specific language governing permissions and limitations
// under the License.
#ifndef DORIS_BE_SRC_QUERY_EXEC_SCHEMA_SCANNER_H
#define DORIS_BE_SRC_QUERY_EXEC_SCHEMA_SCANNER_H
#include <string>
#include "common/status.h"
#include "common/object_pool.h"
#include "gen_cpp/Descriptors_types.h"
#include "runtime/tuple.h"
#include "runtime/mem_pool.h"
namespace doris {
// forehead declar class, because jni function init in DorisServer.
class DorisServer;
class RuntimeState;
// scanner parameter from frontend
struct SchemaScannerParam {
const std::string* db;
const std::string* table;
const std::string* wild;
const std::string* user;
const std::string* user_ip;
const std::string* ip;
int32_t port;
int64_t thread_id;
SchemaScannerParam()
: db(NULL), table(NULL), wild(NULL), user(NULL), user_ip(NULL), ip(NULL), port(0) { }
};
// virtual scanner for all schema table
class SchemaScanner {
public:
struct ColumnDesc {
const char* name;
PrimitiveType type;
int size;
bool is_null;
};
SchemaScanner(ColumnDesc* columns, int column_num);
virtual ~SchemaScanner();
// init object need infomation, schema etc.
virtual Status init(SchemaScannerParam* param, ObjectPool* pool);
// Start to work
virtual Status start(RuntimeState* state);
virtual Status get_next_row(Tuple* tuple, MemPool* pool, bool* eos);
// factory function
static SchemaScanner* create(TSchemaTableType::type type);
const TupleDescriptor* tuple_desc() const {
return _tuple_desc;
}
static void set_doris_server(DorisServer* doris_server) {
_s_doris_server = doris_server;
}
protected:
Status create_tuple_desc(ObjectPool* pool);
bool _is_init;
// this is used for sub class
SchemaScannerParam* _param;
// pointer to schema table's column desc
ColumnDesc* _columns;
// num of columns
int _column_num;
TupleDescriptor* _tuple_desc;
static DorisServer* _s_doris_server;
};
}
#endif