fix some sql logical plan bug

This commit is contained in:
zzg19950727
2024-02-06 19:45:53 +00:00
committed by ob-robot
parent 5b35b464d6
commit 58b436c230
9 changed files with 257 additions and 47 deletions

View File

@ -26,6 +26,7 @@ namespace oceanbase
{
namespace common {
class ObObj;
class ObDSResultItem;
}
using namespace common;
namespace sql
@ -163,7 +164,6 @@ inline ObOptimizerTraceImpl** get_local_tracer()
#define OPT_TRACE_STATIS(stmt, table_metas) \
do { \
CHECK_TRACE_ENABLED { \
tracer->append_title("BASIC TABLE STATIS"); \
tracer->trace_static(stmt, table_metas); \
} \
} while (0); \
@ -264,6 +264,7 @@ public:
int append(const TableItem *table);
int append(const ObShardingInfo *info);
int append(const CandidatePlan &plan);
int append(const ObDSResultItem &ds_result);
/***********************************************/
////print template type
/***********************************************/
@ -292,6 +293,11 @@ public:
typename std::enable_if<std::is_base_of<ObIArray<int64_t>, T>::value, int>::type
append(const T& value);
//for ObIArray<ObDSResultItem>
template <typename T>
typename std::enable_if<std::is_base_of<ObIArray<ObDSResultItem>, T>::value, int>::type
append(const T& value);
//template for function append
template<typename T1, typename T2, typename ...ARGS>
int append(const T1& value1, const T2& value2, const ARGS&... args);
@ -423,6 +429,20 @@ ObOptimizerTraceImpl::append(const T& value)
return ret;
}
//for ObIArray<ObDSResultItem>
template <typename T>
typename std::enable_if<std::is_base_of<ObIArray<ObDSResultItem>, T>::value, int>::type
ObOptimizerTraceImpl::append(const T& value)
{
int ret = OB_SUCCESS;
for (int i = 0; OB_SUCC(ret) && i < value.count(); ++i) {
if (OB_FAIL(append(value.at(i)))) {
} else if (OB_FAIL(new_line())) {
}
}
return ret;
}
//template for function append
template<typename T1, typename T2, typename ...ARGS>
int ObOptimizerTraceImpl::append(const T1& value1, const T2& value2, const ARGS&... args)