greenplumn CDXLDatumStatsDoubleMappable 源码

  • 2022-08-18
  • 浏览 (266)

greenplumn CDXLDatumStatsDoubleMappable 代码

文件路径:/src/backend/gporca/libnaucrates/include/naucrates/dxl/operators/CDXLDatumStatsDoubleMappable.h

//---------------------------------------------------------------------------
//	Greenplum Database
//	Copyright (C) 2014 VMware, Inc. or its affiliates.
//
//	@filename:
//		CDXLDatumStatsDoubleMappable.h
//
//	@doc:
//		Class for representing DXL datum of types having double mapping
//
//	@owner:
//
//
//	@test:
//
//---------------------------------------------------------------------------

#ifndef GPDXL_CDXLDatumStatsDoubleMappable_H
#define GPDXL_CDXLDatumStatsDoubleMappable_H

#include "gpos/base.h"
#include "gpos/common/CDouble.h"

#include "naucrates/dxl/operators/CDXLDatumGeneric.h"

namespace gpdxl
{
using namespace gpos;

// fwd decl
class CXMLSerializer;

//---------------------------------------------------------------------------
//	@class:
//		CDXLDatumStatsDoubleMappable
//
//	@doc:
//		Class for representing DXL datum of types having double mapping
//
//---------------------------------------------------------------------------
class CDXLDatumStatsDoubleMappable : public CDXLDatumGeneric
{
private:
	// for statistics computation, map to double
	CDouble m_val;

public:
	CDXLDatumStatsDoubleMappable(const CDXLDatumStatsDoubleMappable &) = delete;

	// ctor
	CDXLDatumStatsDoubleMappable(CMemoryPool *mp, IMDId *mdid_type,
								 INT type_modifier, BOOL is_null, BYTE *data,
								 ULONG length, CDouble val);

	// dtor
	~CDXLDatumStatsDoubleMappable() override = default;

	// serialize the datum as the given element
	void Serialize(CXMLSerializer *xml_serializer) override;

	// datum type
	EdxldatumType
	GetDatumType() const override
	{
		return CDXLDatum::EdxldatumStatsDoubleMappable;
	}

	// statistics related APIs

	// can datum be mapped to double
	BOOL
	IsDatumMappableToDouble() const override
	{
		return true;
	}

	// return the double mapping needed for statistics computation
	CDouble
	GetDoubleMapping() const override
	{
		return m_val;
	}

	// conversion function
	static CDXLDatumStatsDoubleMappable *
	Cast(CDXLDatum *dxl_datum)
	{
		GPOS_ASSERT(nullptr != dxl_datum);
		GPOS_ASSERT(CDXLDatum::EdxldatumStatsDoubleMappable ==
					dxl_datum->GetDatumType());

		return dynamic_cast<CDXLDatumStatsDoubleMappable *>(dxl_datum);
	}
};
}  // namespace gpdxl

#endif	// !GPDXL_CDXLDatumStatsDoubleMappable_H

// EOF

相关信息

greenplumn 源码目录

相关文章

greenplumn CDXLColDescr 源码

greenplumn CDXLColRef 源码

greenplumn CDXLCtasStorageOptions 源码

greenplumn CDXLDatum 源码

greenplumn CDXLDatumBool 源码

greenplumn CDXLDatumGeneric 源码

greenplumn CDXLDatumInt2 源码

greenplumn CDXLDatumInt4 源码

greenplumn CDXLDatumInt8 源码

greenplumn CDXLDatumOid 源码

0  赞