greenplumn CPhysicalCorrelatedInLeftSemiNLJoin 源码
greenplumn CPhysicalCorrelatedInLeftSemiNLJoin 代码
文件路径:/src/backend/gporca/libgpopt/include/gpopt/operators/CPhysicalCorrelatedInLeftSemiNLJoin.h
//---------------------------------------------------------------------------
// Greenplum Database
// Copyright (C) 2014 VMware, Inc. or its affiliates.
//
// @filename:
// CPhysicalCorrelatedInLeftSemiNLJoin.h
//
// @doc:
// Physical Left Semi NLJ operator capturing correlated execution
// with IN/ANY semantics
//---------------------------------------------------------------------------
#ifndef GPOPT_CPhysicalCorrelatedInLeftSemiNLJoin_H
#define GPOPT_CPhysicalCorrelatedInLeftSemiNLJoin_H
#include "gpos/base.h"
#include "gpopt/operators/CPhysicalLeftSemiNLJoin.h"
namespace gpopt
{
//---------------------------------------------------------------------------
// @class:
// CPhysicalCorrelatedInLeftSemiNLJoin
//
// @doc:
// Physical left semi NLJ operator capturing correlated execution with
// ANY/IN semantics
//
//---------------------------------------------------------------------------
class CPhysicalCorrelatedInLeftSemiNLJoin : public CPhysicalLeftSemiNLJoin
{
private:
// columns from inner child used in correlated execution
CColRefArray *m_pdrgpcrInner;
// origin subquery id
EOperatorId m_eopidOriginSubq;
public:
CPhysicalCorrelatedInLeftSemiNLJoin(
const CPhysicalCorrelatedInLeftSemiNLJoin &) = delete;
// ctor
CPhysicalCorrelatedInLeftSemiNLJoin(CMemoryPool *mp,
CColRefArray *pdrgpcrInner,
EOperatorId eopidOriginSubq)
: CPhysicalLeftSemiNLJoin(mp),
m_pdrgpcrInner(pdrgpcrInner),
m_eopidOriginSubq(eopidOriginSubq)
{
GPOS_ASSERT(nullptr != pdrgpcrInner);
SetDistrRequests(UlDistrRequestsForCorrelatedJoin());
GPOS_ASSERT(0 < UlDistrRequests());
}
// dtor
~CPhysicalCorrelatedInLeftSemiNLJoin() override
{
m_pdrgpcrInner->Release();
}
// ident accessors
EOperatorId
Eopid() const override
{
return EopPhysicalCorrelatedInLeftSemiNLJoin;
}
// return a string for operator name
const CHAR *
SzId() const override
{
return "CPhysicalCorrelatedInLeftSemiNLJoin";
}
// match function
BOOL
Matches(COperator *pop) const override
{
if (pop->Eopid() == Eopid())
{
return m_pdrgpcrInner->Equals(
CPhysicalCorrelatedInLeftSemiNLJoin::PopConvert(pop)
->PdrgPcrInner());
}
return false;
}
// distribution matching type
CEnfdDistribution::EDistributionMatching
Edm(CReqdPropPlan *, // prppInput
ULONG, // child_index
CDrvdPropArray *, //pdrgpdpCtxt
ULONG // ulOptReq
) override
{
return CEnfdDistribution::EdmSatisfy;
}
CEnfdDistribution *
Ped(CMemoryPool *mp, CExpressionHandle &exprhdl, CReqdPropPlan *prppInput,
ULONG child_index, CDrvdPropArray *pdrgpdpCtxt, ULONG ulOptReq) override
{
return PedCorrelatedJoin(mp, exprhdl, prppInput, child_index,
pdrgpdpCtxt, ulOptReq);
}
// compute required distribution of the n-th child
CDistributionSpec *
PdsRequired(CMemoryPool *, // mp
CExpressionHandle &, // exprhdl,
CDistributionSpec *, // pdsRequired,
ULONG, // child_index,
CDrvdPropArray *, // pdrgpdpCtxt,
ULONG //ulOptReq
) const override
{
GPOS_RAISE(
CException::ExmaInvalid, CException::ExmiInvalid,
GPOS_WSZ_LIT(
"PdsRequired should not be called for CPhysicalCorrelatedInLeftSemiNLJoin"));
return nullptr;
}
// compute required rewindability of the n-th child
CRewindabilitySpec *
PrsRequired(CMemoryPool *mp, CExpressionHandle &exprhdl,
CRewindabilitySpec *prsRequired, ULONG child_index,
CDrvdPropArray *pdrgpdpCtxt, ULONG ulOptReq) const override
{
return PrsRequiredCorrelatedJoin(mp, exprhdl, prsRequired, child_index,
pdrgpdpCtxt, ulOptReq);
}
// conversion function
static CPhysicalCorrelatedInLeftSemiNLJoin *
PopConvert(COperator *pop)
{
GPOS_ASSERT(nullptr != pop);
GPOS_ASSERT(EopPhysicalCorrelatedInLeftSemiNLJoin == pop->Eopid());
return dynamic_cast<CPhysicalCorrelatedInLeftSemiNLJoin *>(pop);
}
// return true if operator is a correlated NL Join
BOOL
FCorrelated() const override
{
return true;
}
// return required inner columns
CColRefArray *
PdrgPcrInner() const override
{
return m_pdrgpcrInner;
}
// origin subquery id
EOperatorId
EopidOriginSubq() const
{
return m_eopidOriginSubq;
}
// print
IOstream &
OsPrint(IOstream &os) const override
{
os << this->SzId() << "(";
(void) CUtils::OsPrintDrgPcr(os, m_pdrgpcrInner);
os << ")";
return os;
}
}; // class CPhysicalCorrelatedInLeftSemiNLJoin
} // namespace gpopt
#endif // !GPOPT_CPhysicalCorrelatedInLeftSemiNLJoin_H
// EOF
相关信息
相关文章
greenplumn CExpressionFactorizer 源码
greenplumn CExpressionHandle 源码
greenplumn CExpressionPreprocessor 源码
greenplumn CExpressionUtils 源码
0
赞
热门推荐
-
2、 - 优质文章
-
3、 gate.io
-
7、 golang
-
9、 openharmony
-
10、 Vue中input框自动聚焦