ClickHouse/dbms/src/Storages/StorageInput.h
2020-01-31 17:26:51 +03:00

37 lines
957 B
C++

#pragma once
#include <Storages/IStorage.h>
#include <ext/shared_ptr_helper.h>
namespace DB
{
/** Internal temporary storage for table function input(...)
*/
class StorageInput : public ext::shared_ptr_helper<StorageInput>, public IStorage
{
friend struct ext::shared_ptr_helper<StorageInput>;
public:
String getName() const override { return "Input"; }
/// A table will read from this stream.
void setInputStream(BlockInputStreamPtr input_stream_);
Pipes readWithProcessors(
const Names & column_names,
const SelectQueryInfo & query_info,
const Context & context,
QueryProcessingStage::Enum processed_stage,
size_t max_block_size,
unsigned num_streams) override;
bool supportProcessorsPipeline() const override { return true; }
private:
BlockInputStreamPtr input_stream;
protected:
StorageInput(const String & table_name_, const ColumnsDescription & columns_);
};
}