greenplumn CMDScalarOpGPDB 源码
greenplumn CMDScalarOpGPDB 代码
文件路径:/src/backend/gporca/libnaucrates/include/naucrates/md/CMDScalarOpGPDB.h
//---------------------------------------------------------------------------
// Greenplum Database
// Copyright (C) 2011 EMC Corp.
//
// @filename:
// CMDScalarOpGPDB.h
//
// @doc:
// Class for representing GPDB-specific scalar operators in the MD cache
//---------------------------------------------------------------------------
#ifndef GPMD_CMDScalarOpGPDB_H
#define GPMD_CMDScalarOpGPDB_H
#include "gpos/base.h"
#include "naucrates/md/IMDScalarOp.h"
namespace gpmd
{
using namespace gpos;
//---------------------------------------------------------------------------
// @class:
// CMDScalarOpGPDB
//
// @doc:
// Class for representing GPDB-specific scalar operators in the MD cache
//
//---------------------------------------------------------------------------
class CMDScalarOpGPDB : public IMDScalarOp
{
private:
// memory pool
CMemoryPool *m_mp;
// DXL for object
const CWStringDynamic *m_dxl_str;
// operator id
IMDId *m_mdid;
// operator name
CMDName *m_mdname;
// type of left operand
IMDId *m_mdid_type_left;
// type of right operand
IMDId *m_mdid_type_right;
// type of result operand
IMDId *m_mdid_type_result;
// id of function which implements the operator
IMDId *m_func_mdid;
// id of commute operator
IMDId *m_mdid_commute_opr;
// id of inverse operator
IMDId *m_mdid_inverse_opr;
// comparison type for comparison operators
IMDType::ECmpType m_comparision_type;
// does operator return NULL when all inputs are NULL?
BOOL m_returns_null_on_null_input;
// operator classes this operator belongs to
IMdIdArray *m_mdid_opfamilies_array;
// compatible hash op family
IMDId *m_mdid_hash_opfamily;
// compatible legacy hash op family using legacy (cdbhash) opclass
IMDId *m_mdid_legacy_hash_opfamily;
// does operator preserve the NDV of its input(s)
// (used for cardinality estimation)
BOOL m_is_ndv_preserving;
public:
CMDScalarOpGPDB(const CMDScalarOpGPDB &) = delete;
// ctor/dtor
CMDScalarOpGPDB(CMemoryPool *mp, IMDId *mdid, CMDName *mdname,
IMDId *mdid_type_left, IMDId *mdid_type_right,
IMDId *result_type_mdid, IMDId *mdid_func,
IMDId *mdid_commute_opr, IMDId *m_mdid_inverse_opr,
IMDType::ECmpType cmp_type, BOOL returns_null_on_null_input,
IMdIdArray *mdid_opfamilies_array,
IMDId *m_mdid_hash_opfamily,
IMDId *mdid_legacy_hash_opfamily, BOOL is_ndv_preserving);
~CMDScalarOpGPDB() override;
// accessors
const CWStringDynamic *
GetStrRepr() const override
{
return m_dxl_str;
}
// operator id
IMDId *MDId() const override;
// operator name
CMDName Mdname() const override;
// left operand type id
IMDId *GetLeftMdid() const override;
// right operand type id
IMDId *GetRightMdid() const override;
// resulttype id
IMDId *GetResultTypeMdid() const override;
// implementer function id
IMDId *FuncMdId() const override;
// commutor id
IMDId *GetCommuteOpMdid() const override;
// inverse operator id
IMDId *GetInverseOpMdid() const override;
// is this an equality operator
BOOL IsEqualityOp() const override;
// does operator return NULL when all inputs are NULL?
// STRICT implies NULL-returning, but the opposite is not always true,
// the implementation in GPDB returns what STRICT property states
BOOL ReturnsNullOnNullInput() const override;
// preserves NDVs of its inputs?
BOOL IsNDVPreserving() const override;
// comparison type
IMDType::ECmpType ParseCmpType() const override;
// serialize object in DXL format
void Serialize(gpdxl::CXMLSerializer *xml_serializer) const override;
// number of classes this operator belongs to
ULONG OpfamiliesCount() const override;
// operator class at given position
IMDId *OpfamilyMdidAt(ULONG pos) const override;
// compatible hash opfamily
IMDId *HashOpfamilyMdid() const override;
#ifdef GPOS_DEBUG
// debug print of the type in the provided stream
void DebugPrint(IOstream &os) const override;
#endif
};
} // namespace gpmd
#endif // !GPMD_CMDScalarOpGPDB_H
// EOF
相关信息
相关文章
greenplumn CDXLStatsDerivedColumn 源码
greenplumn CDXLStatsDerivedRelation 源码
greenplumn CMDAggregateGPDB 源码
0
赞
热门推荐
-
2、 - 优质文章
-
3、 gate.io
-
7、 golang
-
9、 openharmony
-
10、 Vue中input框自动聚焦