ClickHouse/dbms/include/DB/Dictionaries/IDictionary.h

87 lines
1.9 KiB
C++
Raw Normal View History

#pragma once
#include <DB/Core/Field.h>
2015-02-03 17:03:35 +00:00
#include <DB/Core/StringRef.h>
#include <Poco/Util/XMLConfiguration.h>
#include <DB/Common/PODArray.h>
#include <memory>
#include <chrono>
namespace DB
{
class IDictionarySource;
2016-03-07 04:31:10 +00:00
struct IDictionaryBase;
using DictionaryPtr = std::unique_ptr<IDictionaryBase>;
2016-03-07 04:31:10 +00:00
struct DictionaryLifetime;
struct DictionaryStructure;
class ColumnString;
struct IDictionaryBase
{
using Key = UInt64;
virtual std::exception_ptr getCreationException() const = 0;
virtual std::string getName() const = 0;
virtual std::string getTypeName() const = 0;
2015-03-24 11:30:16 +00:00
virtual std::size_t getBytesAllocated() const = 0;
virtual std::size_t getQueryCount() const = 0;
virtual double getHitRate() const = 0;
virtual std::size_t getElementCount() const = 0;
virtual double getLoadFactor() const = 0;
virtual bool isCached() const = 0;
virtual DictionaryPtr clone() const = 0;
virtual const IDictionarySource * getSource() const = 0;
virtual const DictionaryLifetime & getLifetime() const = 0;
virtual const DictionaryStructure & getStructure() const = 0;
virtual std::chrono::time_point<std::chrono::system_clock> getCreationTime() const = 0;
virtual bool isInjective(const std::string & attribute_name) const = 0;
virtual ~IDictionaryBase() = default;
};
struct IDictionary : IDictionaryBase
{
virtual bool hasHierarchy() const = 0;
2016-08-07 09:09:18 +00:00
virtual void toParent(const PaddedPODArray<Key> & ids, PaddedPODArray<Key> & out) const = 0;
2016-08-07 09:09:18 +00:00
virtual void has(const PaddedPODArray<Key> & ids, PaddedPODArray<UInt8> & out) const = 0;
/// do not call unless you ensure that hasHierarchy() returns true
2016-08-07 09:09:18 +00:00
Key toParent(Key id) const
{
const PaddedPODArray<UInt64> ids(1, id);
PaddedPODArray<UInt64> out(1);
toParent(ids, out);
return out.front();
}
2016-08-07 09:09:18 +00:00
bool in(Key child_id, const Key ancestor_id) const
{
while (child_id != 0 && child_id != ancestor_id)
child_id = toParent(child_id);
return child_id != 0;
}
};
}