#pragma once #include #include #include #include #include #include #include #include #include namespace DB { struct IDictionaryBase; using DictionaryPtr = std::unique_ptr; struct DictionaryStructure; class ColumnString; class IBlockInputStream; using BlockInputStreamPtr = std::shared_ptr; struct IDictionaryBase : public IExternalLoadable { using Key = UInt64; virtual std::string getTypeName() const = 0; virtual size_t getBytesAllocated() const = 0; virtual size_t getQueryCount() const = 0; virtual double getHitRate() const = 0; virtual size_t getElementCount() const = 0; virtual double getLoadFactor() const = 0; virtual bool isCached() const = 0; virtual const IDictionarySource * getSource() const = 0; virtual const DictionaryStructure & getStructure() const = 0; virtual bool isInjective(const std::string & attribute_name) const = 0; virtual BlockInputStreamPtr getBlockInputStream(const Names & column_names, size_t max_block_size) const = 0; bool supportUpdates() const override { return !isCached(); } bool isModified() const override { auto source = getSource(); return source && source->isModified(); } std::shared_ptr shared_from_this() { return std::static_pointer_cast(IExternalLoadable::shared_from_this()); } std::shared_ptr shared_from_this() const { return std::static_pointer_cast(IExternalLoadable::shared_from_this()); } }; struct IDictionary : IDictionaryBase { virtual bool hasHierarchy() const = 0; virtual void toParent(const PaddedPODArray & ids, PaddedPODArray & out) const = 0; virtual void has(const PaddedPODArray & ids, PaddedPODArray & out) const = 0; /// Methods for hierarchy. virtual void isInVectorVector(const PaddedPODArray & /*child_ids*/, const PaddedPODArray & /*ancestor_ids*/, PaddedPODArray & /*out*/) const { throw Exception("Hierarchy is not supported for " + getName() + " dictionary.", ErrorCodes::NOT_IMPLEMENTED); } virtual void isInVectorConstant(const PaddedPODArray & /*child_ids*/, const Key /*ancestor_id*/, PaddedPODArray & /*out*/) const { throw Exception("Hierarchy is not supported for " + getName() + " dictionary.", ErrorCodes::NOT_IMPLEMENTED); } virtual void isInConstantVector(const Key /*child_id*/, const PaddedPODArray & /*ancestor_ids*/, PaddedPODArray & /*out*/) const { throw Exception("Hierarchy is not supported for " + getName() + " dictionary.", ErrorCodes::NOT_IMPLEMENTED); } void isInConstantConstant(const Key child_id, const Key ancestor_id, UInt8 & out) const { PaddedPODArray out_arr(1); isInVectorConstant(PaddedPODArray(1, child_id), ancestor_id, out_arr); out = out_arr[0]; } }; }