#pragma once #include #include #include #include #include namespace DB { /* Implements storage in the Redis. * Use ENGINE = Redis(host:port[, db_index[, password[, pool_size]]]) PRIMARY KEY(key); */ class StorageRedis : public IStorage, public IKeyValueEntity, WithContext { public: StorageRedis( const StorageID & table_id_, const RedisConfiguration & configuration_, ContextPtr context_, const StorageInMemoryMetadata & storage_metadata, const String & primary_key_); std::string getName() const override { return "Redis"; } Pipe read( const Names & column_names, const StorageSnapshotPtr & storage_snapshot, SelectQueryInfo & query_info, ContextPtr context_, QueryProcessingStage::Enum processed_stage, size_t max_block_size, size_t num_streams) override; SinkToStoragePtr write( const ASTPtr & query, const StorageMetadataPtr & /*metadata_snapshot*/, ContextPtr context) override; Names getPrimaryKey() const override { return {primary_key}; } /// Return chunk with data for given serialized keys. /// If out_null_map is passed, fill it with 1/0 depending on key was/wasn't found. Result chunk may contain default values. /// If out_null_map is not passed. Not found rows excluded from result chunk. Chunk getBySerializedKeys( const std::vector & keys, PaddedPODArray * out_null_map) const; Chunk getBySerializedKeys( const RedisArray & keys, PaddedPODArray * out_null_map) const; std::pair scan(RedisIterator iterator, const String & pattern, const uint64_t max_count); RedisArray multiGet(const RedisArray & keys) const; Chunk getByKeys(const ColumnsWithTypeAndName & keys, PaddedPODArray & null_map, const Names &) const override; Block getSampleBlock(const Names &) const override; private: StorageID table_id; RedisConfiguration configuration; Poco::Logger * log; RedisPoolPtr pool; const String primary_key; }; }