#pragma once #include #include #include #include #include namespace DB { /** Implements storage in the RAM. * Suitable for temporary data. * It does not support keys. * Data is stored as a set of blocks and is not stored anywhere else. */ class StorageMemory : public ext::shared_ptr_helper, public IStorage { friend class MemoryBlockInputStream; friend class MemoryBlockOutputStream; public: std::string getName() const override { return "Memory"; } std::string getTableName() const override { return table_name; } size_t getSize() const { return data.size(); } BlockInputStreams read( const Names & column_names, const SelectQueryInfo & query_info, const Context & context, QueryProcessingStage::Enum processed_stage, size_t max_block_size, unsigned num_streams) override; BlockOutputStreamPtr write(const ASTPtr & query, const Settings & settings) override; void drop() override; void truncate(const ASTPtr &) override; void rename(const String & /*new_path_to_db*/, const String & /*new_database_name*/, const String & new_table_name) override { table_name = new_table_name; } private: String table_name; /// The data itself. `list` - so that when inserted to the end, the existing iterators are not invalidated. BlocksList data; std::mutex mutex; protected: StorageMemory(String table_name_, ColumnsDescription columns_description_); }; }