Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
844c5ac4
T
TDengine
项目概览
taosdata
/
TDengine
接近 2 年 前同步成功
通知
1192
Star
22018
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看板
提交
844c5ac4
编写于
12月 22, 2021
作者:
dengyihao
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
update tindex write
上级
ecc43580
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
59 addition
and
1 deletion
+59
-1
source/libs/index/src/index_tfile.c
source/libs/index/src/index_tfile.c
+59
-1
未找到文件。
source/libs/index/src/index_tfile.c
浏览文件 @
844c5ac4
...
...
@@ -21,7 +21,33 @@
#include "index_fst_counting_writer.h"
#include "index_util.h"
#include "taosdef.h"
#include "tcompare.h"
#define TF_TABLE_TATOAL_SIZE(sz) (sizeof(sz) + sz * sizeof(uint64_t))
typedef
struct
TFileValue
{
char
*
colVal
;
// null terminated
SArray
*
tableId
;
int32_t
offset
;
}
TFileValue
;
// static tfileGetCompareFunc(uint8_t byte) {}
static
int
tfileValueCompare
(
const
void
*
a
,
const
void
*
b
,
const
void
*
param
)
{
__compar_fn_t
fn
=
*
(
__compar_fn_t
*
)
param
;
TFileValue
*
av
=
(
TFileValue
*
)
a
;
TFileValue
*
bv
=
(
TFileValue
*
)
b
;
return
fn
(
av
->
colVal
,
bv
->
colVal
);
}
static
void
tfileSerialTableIdsToBuf
(
char
*
buf
,
SArray
*
tableIds
)
{
int
tbSz
=
taosArrayGetSize
(
tableIds
);
SERIALIZE_VAR_TO_BUF
(
buf
,
tbSz
,
int32_t
);
for
(
size_t
i
=
0
;
i
<
tbSz
;
i
++
)
{
uint64_t
*
v
=
taosArrayGet
(
tableIds
,
i
);
SERIALIZE_VAR_TO_BUF
(
buf
,
*
v
,
uint64_t
);
}
}
static
FORCE_INLINE
int
tfileWriteHeader
(
TFileWriter
*
writer
)
{
char
buf
[
TFILE_HEADER_SIZE
]
=
{
0
};
char
*
p
=
buf
;
...
...
@@ -245,9 +271,41 @@ TFileWriter* tfileWriterCreate(WriterCtx* ctx, TFileHeader* header) {
}
int
TFileWriterPut
(
TFileWriter
*
tw
,
void
*
data
)
{
// sort by coltype and write to tindex
__compar_fn_t
fn
=
getComparFunc
(
tw
->
header
.
colType
,
0
);
taosArraySortPWithExt
((
SArray
*
)(
data
),
tfileValueCompare
,
&
fn
);
int32_t
bufLimit
=
4096
,
offset
=
0
;
char
*
buf
=
calloc
(
1
,
sizeof
(
bufLimit
));
char
*
p
=
buf
;
int32_t
sz
=
taosArrayGetSize
((
SArray
*
)
data
);
for
(
size_t
i
=
0
;
i
<
sz
;
i
++
)
{
TFileValue
*
v
=
taosArrayGetP
((
SArray
*
)
data
,
i
);
int32_t
tbsz
=
taosArrayGetSize
(
v
->
tableId
);
// check buf has enough space or not
int32_t
ttsz
=
TF_TABLE_TATOAL_SIZE
(
tbsz
);
if
(
offset
+
ttsz
>
bufLimit
)
{
// batch write
tw
->
ctx
->
write
(
tw
->
ctx
,
buf
,
offset
);
offset
=
0
;
memset
(
buf
,
0
,
bufLimit
);
p
=
buf
;
}
tfileSerialTableIdsToBuf
(
p
,
v
->
tableId
);
offset
+=
ttsz
;
p
=
buf
+
offset
;
// set up value offset and
v
->
offset
=
tw
->
offset
;
tw
->
offset
+=
ttsz
;
}
if
(
offset
!=
0
)
{
// write reversed data in buf to tindex
tw
->
ctx
->
write
(
tw
->
ctx
,
buf
,
offset
);
}
// sort by and write to
tfree
(
buf
);
return
0
;
}
void
tfileWriterDestroy
(
TFileWriter
*
tw
)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录