Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
7570a449
T
TDengine
项目概览
taosdata
/
TDengine
11 个月 前同步成功
通知
1179
Star
22014
Fork
4786
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
TDengine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
7570a449
编写于
7月 17, 2022
作者:
S
shenglian zhou
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
feat: add user tags
上级
97d30c68
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
56 addition
and
30 deletion
+56
-30
source/libs/executor/src/scanoperator.c
source/libs/executor/src/scanoperator.c
+56
-30
未找到文件。
source/libs/executor/src/scanoperator.c
浏览文件 @
7570a449
...
...
@@ -1766,73 +1766,80 @@ static SSDataBlock* buildInfoSchemaTableMetaBlock(char* tableName) {
return
pBlock
;
}
//TODO: check more datatype, json? and return detailed error when len is not enough
static
int32_t
convertTagDataToVarchar
(
int8_t
tagType
,
char
*
tagVal
,
char
*
str
,
size_t
len
)
{
// TODO: check more datatype, json? and return detailed error when len is not enough
static
int32_t
convertTagDataToTagVarchar
(
int8_t
tagType
,
char
*
tagVal
,
uint32_t
tagLen
,
char
*
varData
,
int32_t
bufSize
)
{
int
outputLen
=
-
1
;
switch
(
tagType
)
{
case
TSDB_DATA_TYPE_TINYINT
:
snprintf
(
str
,
len
,
"%d"
,
*
((
int8_t
*
)
tagVal
));
outputLen
=
snprintf
(
varDataVal
(
varData
),
bufSize
,
"%d"
,
*
((
int8_t
*
)
tagVal
));
break
;
case
TSDB_DATA_TYPE_UTINYINT
:
snprintf
(
str
,
len
,
"%u"
,
*
((
uint8_t
*
)
tagVal
));
outputLen
=
snprintf
(
varDataVal
(
varData
),
bufSize
,
"%u"
,
*
((
uint8_t
*
)
tagVal
));
break
;
case
TSDB_DATA_TYPE_SMALLINT
:
snprintf
(
str
,
len
,
"%d"
,
*
((
int16_t
*
)
tagVal
));
outputLen
=
snprintf
(
varDataVal
(
varData
),
bufSize
,
"%d"
,
*
((
int16_t
*
)
tagVal
));
break
;
case
TSDB_DATA_TYPE_USMALLINT
:
snprintf
(
str
,
len
,
"%u"
,
*
((
uint16_t
*
)
tagVal
));
outputLen
=
snprintf
(
varDataVal
(
varData
),
bufSize
,
"%u"
,
*
((
uint16_t
*
)
tagVal
));
break
;
case
TSDB_DATA_TYPE_INT
:
snprintf
(
str
,
len
,
"%d"
,
*
((
int32_t
*
)
tagVal
));
outputLen
=
snprintf
(
varDataVal
(
varData
),
bufSize
,
"%d"
,
*
((
int32_t
*
)
tagVal
));
break
;
case
TSDB_DATA_TYPE_UINT
:
snprintf
(
str
,
len
,
"%u"
,
*
((
uint32_t
*
)
tagVal
));
outputLen
=
snprintf
(
varDataVal
(
varData
),
bufSize
,
"%u"
,
*
((
uint32_t
*
)
tagVal
));
break
;
case
TSDB_DATA_TYPE_BIGINT
:
snprintf
(
str
,
len
,
"%"
PRId64
,
*
((
int64_t
*
)
tagVal
));
outputLen
=
snprintf
(
varDataVal
(
varData
),
bufSize
,
"%"
PRId64
,
*
((
int64_t
*
)
tagVal
));
break
;
case
TSDB_DATA_TYPE_UBIGINT
:
snprintf
(
str
,
len
,
"%"
PRIu64
,
*
((
uint64_t
*
)
tagVal
));
outputLen
=
snprintf
(
varDataVal
(
varData
),
bufSize
,
"%"
PRIu64
,
*
((
uint64_t
*
)
tagVal
));
break
;
case
TSDB_DATA_TYPE_FLOAT
:
{
float
fv
=
0
;
fv
=
GET_FLOAT_VAL
(
tagVal
);
snprintf
(
str
,
len
,
"%f"
,
fv
);
outputLen
=
snprintf
(
varDataVal
(
varData
),
bufSize
,
"%f"
,
fv
);
break
;
}
case
TSDB_DATA_TYPE_DOUBLE
:
{
double
dv
=
0
;
dv
=
GET_DOUBLE_VAL
(
tagVal
);
snprintf
(
str
,
len
,
"%lf"
,
dv
);
outputLen
=
snprintf
(
varDataVal
(
varData
),
bufSize
,
"%lf"
,
dv
);
break
;
}
case
TSDB_DATA_TYPE_BINARY
:
case
TSDB_DATA_TYPE_NCHAR
:
case
TSDB_DATA_TYPE_JSON
:
{
memcpy
(
str
,
tagVal
,
len
);
memcpy
(
varDataVal
(
varData
),
tagVal
,
tagLen
);
outputLen
=
tagLen
;
break
;
}
case
TSDB_DATA_TYPE_TIMESTAMP
:
snprintf
(
str
,
len
,
"%"
PRId64
,
*
((
int64_t
*
)
tagVal
));
outputLen
=
snprintf
(
varDataVal
(
varData
),
bufSize
,
"%"
PRId64
,
*
((
int64_t
*
)
tagVal
));
break
;
case
TSDB_DATA_TYPE_BOOL
:
snprintf
(
str
,
len
,
"%d"
,
*
((
int8_t
*
)
tagVal
));
outputLen
=
snprintf
(
varDataVal
(
varData
),
bufSize
,
"%d"
,
*
((
int8_t
*
)
tagVal
));
break
;
default:
return
TSDB_CODE_FAILED
;
}
if
(
outputLen
<
0
||
outputLen
==
bufSize
&&
!
IS_VAR_DATA_TYPE
(
tagType
)
||
outputLen
>
bufSize
)
{
return
TSDB_CODE_FAILED
;
}
varDataSetLen
(
varData
,
outputLen
);
return
TSDB_CODE_SUCCESS
;
}
...
...
@@ -1917,25 +1924,44 @@ static SSDataBlock* sysTableScanUserTags(SOperatorInfo* pOperator) {
STagVal
tagVal
=
{
0
};
tagVal
.
cid
=
smr
.
me
.
stbEntry
.
schemaTag
.
pSchema
[
i
].
colId
;
const
char
*
pVal
=
metaGetTableTagVal
(
&
pInfo
->
pCur
->
mr
.
me
,
tagType
,
&
tagVal
);
char
*
tagData
=
NULL
;
if
(
tagType
!=
TSDB_DATA_TYPE_JSON
&&
p
!=
NULL
)
{
tagData
=
tTagValToData
((
const
STagVal
*
)
pVal
,
false
);
char
*
tagData
=
NULL
;
uint32_t
tagLen
=
0
;
if
(
tagType
==
TSDB_DATA_TYPE_JSON
)
{
// TODO: json type?+varheader+data
tagData
=
varDataVal
(
pInfo
->
pCur
->
mr
.
me
.
ctbEntry
.
pTags
+
1
);
tagLen
=
varDataLen
(
pInfo
->
pCur
->
mr
.
me
.
ctbEntry
.
pTags
+
1
);
}
else
{
tagData
=
(
char
*
)
pVal
;
bool
exist
=
tTagGet
((
STag
*
)
pInfo
->
pCur
->
mr
.
me
.
ctbEntry
.
pTags
,
&
tagVal
);
if
(
exist
)
{
if
(
IS_VAR_DATA_TYPE
(
tagType
))
{
tagData
=
(
char
*
)
tagVal
.
pData
;
tagLen
=
tagVal
.
nData
;
}
else
{
tagData
=
(
char
*
)
&
tagVal
.
i64
;
tagLen
=
tDataTypes
[
tagType
].
bytes
;
}
}
}
//TODO: memory allocation for varchar size and make sure enough memory
char
tagStr
[
1024
];
convertTagDataToVarchar
(
tagType
,
tagData
,
tagStr
,
1024
);
pColInfoData
=
taosArrayGet
(
p
->
pDataBlock
,
5
);
colDataAppend
(
pColInfoData
,
numOfRows
,
tagStr
,
(
tagData
==
NULL
)
||
(
tagType
==
TSDB_DATA_TYPE_JSON
&&
tTagIsJsonNull
(
tagData
)));
if
(
tagType
!=
TSDB_DATA_TYPE_JSON
&&
p
!=
NULL
&&
IS_VAR_DATA_TYPE
(((
const
STagVal
*
)
p
)
->
type
)
&&
tagData
!=
NULL
)
{
taosMemoryFree
(
tagData
);
int32_t
bufSize
=
IS_VAR_DATA_TYPE
(
tagType
)
?
tagLen
:
1024
;
char
*
tagVarChar
=
NULL
;
if
(
tagData
!=
NULL
)
{
tagVarChar
=
taosMemoryMalloc
(
bufSize
);
code
=
convertTagDataToTagVarchar
(
tagType
,
tagData
,
tagLen
,
tagVarChar
,
bufSize
);
if
(
code
!=
TSDB_CODE_SUCCESS
)
{
qError
(
"failed to get super table meta, uid:0x%"
PRIx64
", code:%s, %s"
,
suid
,
tstrerror
(
terrno
),
GET_TASKID
(
pTaskInfo
));
taosMemoryFree
(
tagVarChar
);
metaReaderClear
(
&
smr
);
metaCloseTbCursor
(
pInfo
->
pCur
);
pInfo
->
pCur
=
NULL
;
longjmp
(
pTaskInfo
->
env
,
terrno
);
}
}
pColInfoData
=
taosArrayGet
(
p
->
pDataBlock
,
5
);
colDataAppend
(
pColInfoData
,
numOfRows
,
tagVarChar
,
(
tagData
==
NULL
)
||
(
tagType
==
TSDB_DATA_TYPE_JSON
&&
tTagIsJsonNull
(
tagData
)));
taosMemoryFree
(
tagVarChar
);
++
numOfRows
;
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录