未验证 提交 6320fa92 编写于 作者: M Minglei Jin 提交者: GitHub

Merge pull request #13308 from taosdata/feature/TS-1546-2.6

fix(query): fixed related query error caused by tag mismatch
...@@ -2896,7 +2896,7 @@ static bool overlapWithTimeWindow(SQueryAttr* pQueryAttr, SDataBlockInfo* pBlock ...@@ -2896,7 +2896,7 @@ static bool overlapWithTimeWindow(SQueryAttr* pQueryAttr, SDataBlockInfo* pBlock
return false; return false;
} }
static int32_t doTSJoinFilter(SQueryRuntimeEnv *pRuntimeEnv, TSKEY key, bool ascQuery) { static int32_t doTSJoinFilter(SQueryRuntimeEnv *pRuntimeEnv, TSKEY key, tVariant *pTag, bool ascQuery) {
STSElem elem = tsBufGetElem(pRuntimeEnv->pTsBuf); STSElem elem = tsBufGetElem(pRuntimeEnv->pTsBuf);
#if defined(_DEBUG_VIEW) #if defined(_DEBUG_VIEW)
...@@ -2905,6 +2905,10 @@ static int32_t doTSJoinFilter(SQueryRuntimeEnv *pRuntimeEnv, TSKEY key, bool asc ...@@ -2905,6 +2905,10 @@ static int32_t doTSJoinFilter(SQueryRuntimeEnv *pRuntimeEnv, TSKEY key, bool asc
pRuntimeEnv->pTsBuf->cur.order, pRuntimeEnv->pTsBuf->cur.tsIndex); pRuntimeEnv->pTsBuf->cur.order, pRuntimeEnv->pTsBuf->cur.tsIndex);
#endif #endif
if (pTag && elem.tag && tVariantCompare(pTag, elem.tag) != 0) {
return TS_JOIN_TAG_NOT_EQUALS;
}
if (ascQuery) { if (ascQuery) {
if (key < elem.ts) { if (key < elem.ts) {
return TS_JOIN_TS_NOT_EQUALS; return TS_JOIN_TS_NOT_EQUALS;
...@@ -3031,10 +3035,16 @@ void filterRowsInDataBlock(SQueryRuntimeEnv* pRuntimeEnv, SSingleColumnFilterInf ...@@ -3031,10 +3035,16 @@ void filterRowsInDataBlock(SQueryRuntimeEnv* pRuntimeEnv, SSingleColumnFilterInf
if (pRuntimeEnv->pTsBuf != NULL) { if (pRuntimeEnv->pTsBuf != NULL) {
SColumnInfoData* pColInfoData = taosArrayGet(pBlock->pDataBlock, 0); SColumnInfoData* pColInfoData = taosArrayGet(pBlock->pDataBlock, 0);
tVariant tag = { .nType = -1 };
TSKEY* k = (TSKEY*) pColInfoData->pData; TSKEY* k = (TSKEY*) pColInfoData->pData;
for (int32_t i = 0; i < numOfRows; ++i) { for (int32_t i = 0; i < numOfRows; ++i) {
int32_t offset = ascQuery? i:(numOfRows - i - 1); if (tag.nType == -1) {
int32_t ret = doTSJoinFilter(pRuntimeEnv, k[offset], ascQuery); tVariantAssign(&tag, &pRuntimeEnv->pTsBuf->block.tag);
}
int32_t offset = ascQuery? i : (numOfRows - i - 1);
int32_t ret = doTSJoinFilter(pRuntimeEnv, k[offset], &tag, ascQuery);
if (ret == TS_JOIN_TAG_NOT_EQUALS) { if (ret == TS_JOIN_TAG_NOT_EQUALS) {
break; break;
} else if (ret == TS_JOIN_TS_NOT_EQUALS) { } else if (ret == TS_JOIN_TS_NOT_EQUALS) {
...@@ -3045,6 +3055,8 @@ void filterRowsInDataBlock(SQueryRuntimeEnv* pRuntimeEnv, SSingleColumnFilterInf ...@@ -3045,6 +3055,8 @@ void filterRowsInDataBlock(SQueryRuntimeEnv* pRuntimeEnv, SSingleColumnFilterInf
p[offset] = true; p[offset] = true;
} }
tVariantAssign(&tag, &pRuntimeEnv->pTsBuf->block.tag);
if (!tsBufNextPos(pRuntimeEnv->pTsBuf)) { if (!tsBufNextPos(pRuntimeEnv->pTsBuf)) {
if (i < (numOfRows - 1)) { if (i < (numOfRows - 1)) {
all = false; all = false;
...@@ -3077,10 +3089,16 @@ void filterColRowsInDataBlock(SQueryRuntimeEnv* pRuntimeEnv, SSDataBlock* pBlock ...@@ -3077,10 +3089,16 @@ void filterColRowsInDataBlock(SQueryRuntimeEnv* pRuntimeEnv, SSDataBlock* pBlock
SColumnInfoData* pColInfoData = taosArrayGet(pBlock->pDataBlock, 0); SColumnInfoData* pColInfoData = taosArrayGet(pBlock->pDataBlock, 0);
p = calloc(numOfRows, sizeof(int8_t)); p = calloc(numOfRows, sizeof(int8_t));
tVariant tag = { .nType = -1 };
TSKEY* k = (TSKEY*) pColInfoData->pData; TSKEY* k = (TSKEY*) pColInfoData->pData;
for (int32_t i = 0; i < numOfRows; ++i) { for (int32_t i = 0; i < numOfRows; ++i) {
int32_t offset = ascQuery? i:(numOfRows - i - 1); if (tag.nType == -1) {
int32_t ret = doTSJoinFilter(pRuntimeEnv, k[offset], ascQuery); tVariantAssign(&tag, &pRuntimeEnv->pTsBuf->block.tag);
}
int32_t offset = ascQuery ? i : (numOfRows - i - 1);
int32_t ret = doTSJoinFilter(pRuntimeEnv, k[offset], &tag, ascQuery);
if (ret == TS_JOIN_TAG_NOT_EQUALS) { if (ret == TS_JOIN_TAG_NOT_EQUALS) {
break; break;
} else if (ret == TS_JOIN_TS_NOT_EQUALS) { } else if (ret == TS_JOIN_TS_NOT_EQUALS) {
...@@ -3091,6 +3109,8 @@ void filterColRowsInDataBlock(SQueryRuntimeEnv* pRuntimeEnv, SSDataBlock* pBlock ...@@ -3091,6 +3109,8 @@ void filterColRowsInDataBlock(SQueryRuntimeEnv* pRuntimeEnv, SSDataBlock* pBlock
p[offset] = true; p[offset] = true;
} }
tVariantAssign(&tag, &pRuntimeEnv->pTsBuf->block.tag);
if (!tsBufNextPos(pRuntimeEnv->pTsBuf)) { if (!tsBufNextPos(pRuntimeEnv->pTsBuf)) {
if (i < (numOfRows - 1)) { if (i < (numOfRows - 1)) {
all = false; all = false;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册