Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
f1824956
T
TDengine
项目概览
taosdata
/
TDengine
1 年多 前同步成功
通知
1185
Star
22016
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看板
提交
f1824956
编写于
5月 20, 2021
作者:
L
lichuang
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[TD-4034]fix schema change,free not exist column data
上级
b2e30242
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
28 addition
and
19 deletion
+28
-19
src/inc/tsdb.h
src/inc/tsdb.h
+2
-2
src/tsdb/src/tsdbMeta.c
src/tsdb/src/tsdbMeta.c
+26
-17
未找到文件。
src/inc/tsdb.h
浏览文件 @
f1824956
...
@@ -73,8 +73,8 @@ typedef struct {
...
@@ -73,8 +73,8 @@ typedef struct {
}
STsdbCfg
;
}
STsdbCfg
;
#define CACHE_NO_LAST(c) ((c)->cacheLastRow == 0)
#define CACHE_NO_LAST(c) ((c)->cacheLastRow == 0)
#define CACHE_LAST_ROW(c) ((
c)->cacheLastRow == 1
)
#define CACHE_LAST_ROW(c) ((
(c)->cacheLastRow & 1) > 0
)
#define CACHE_LAST_NULL_COLUMN(c) ((
c)->cacheLastRow == 2
)
#define CACHE_LAST_NULL_COLUMN(c) ((
(c)->cacheLastRow & 2) > 0
)
// --------- TSDB REPOSITORY USAGE STATISTICS
// --------- TSDB REPOSITORY USAGE STATISTICS
typedef
struct
{
typedef
struct
{
...
...
src/tsdb/src/tsdbMeta.c
浏览文件 @
f1824956
...
@@ -660,43 +660,52 @@ int tsdbUpdateLastColSchema(STable *pTable, STSchema *pNewSchema) {
...
@@ -660,43 +660,52 @@ int tsdbUpdateLastColSchema(STable *pTable, STSchema *pNewSchema) {
TSDB_WLOCK_TABLE
(
pTable
);
TSDB_WLOCK_TABLE
(
pTable
);
int16_t
oldIdx
=
0
;
for
(
int16_t
i
=
0
;
i
<
numOfCols
;
++
i
)
{
for
(
int16_t
i
=
0
;
i
<
numOfCols
;
++
i
)
{
STColumn
*
pCol
=
schemaColAt
(
pNewSchema
,
i
);
STColumn
*
pCol
=
schemaColAt
(
pNewSchema
,
i
);
int16_t
idx
=
tsdbGetLastColumnsIndexByColId
(
pTable
,
pCol
->
colId
);
int16_t
idx
=
tsdbGetLastColumnsIndexByColId
(
pTable
,
pCol
->
colId
);
SDataCol
*
pDataCol
=
&
(
lastCols
[
i
]);
SDataCol
*
pDataCol
=
&
(
lastCols
[
i
]);
if
(
idx
!=
-
1
)
{
if
(
idx
!=
-
1
)
{
// move col data to new last column array
SDataCol
*
pOldDataCol
=
&
(
pTable
->
lastCols
[
idx
]);
SDataCol
*
pOldDataCol
=
&
(
pTable
->
lastCols
[
idx
]);
memcpy
(
pDataCol
,
pOldDataCol
,
sizeof
(
SDataCol
));
memcpy
(
pDataCol
,
pOldDataCol
,
sizeof
(
SDataCol
));
}
else
{
}
else
{
// init new colid data
pDataCol
->
colId
=
pCol
->
colId
;
pDataCol
->
colId
=
pCol
->
colId
;
pDataCol
->
bytes
=
0
;
pDataCol
->
bytes
=
0
;
pDataCol
->
pData
=
NULL
;
pDataCol
->
pData
=
NULL
;
}
}
// free dropped column data
while
(
oldIdx
<
idx
&&
oldIdx
<
pTable
->
lastColNum
)
{
SDataCol
*
pOldDataCol
=
&
(
pTable
->
lastCols
[
oldIdx
]);
if
(
pOldDataCol
->
bytes
!=
0
)
{
tfree
(
pOldDataCol
->
pData
);
pOldDataCol
->
bytes
=
0
;
}
++
oldIdx
;
}
if
(
idx
!=
-
1
&&
oldIdx
==
idx
)
{
oldIdx
+=
1
;
}
}
}
// free old schema last column datas
SDataCol
*
oldLastCols
=
pTable
->
lastCols
;
tfree
(
pTable
->
lastCols
)
;
int16_t
oldLastColNum
=
pTable
->
lastColNum
;
pTable
->
lastColSVersion
=
schemaVersion
(
pNewSchema
);
pTable
->
lastColSVersion
=
schemaVersion
(
pNewSchema
);
pTable
->
lastCols
=
lastCols
;
pTable
->
lastCols
=
lastCols
;
pTable
->
lastColNum
=
numOfCols
;
pTable
->
lastColNum
=
numOfCols
;
if
(
oldLastCols
==
NULL
)
{
TSDB_WUNLOCK_TABLE
(
pTable
);
TSDB_WUNLOCK_TABLE
(
pTable
);
return
0
;
}
// free old schema last column datas
for
(
int16_t
i
=
0
;
i
<
oldLastColNum
;
++
i
)
{
SDataCol
*
pDataCol
=
&
(
oldLastCols
[
i
]);
if
(
pDataCol
->
bytes
==
0
)
{
continue
;
}
int16_t
idx
=
tsdbGetLastColumnsIndexByColId
(
pTable
,
pDataCol
->
colId
);
if
(
idx
!=
-
1
)
{
continue
;
}
// free not exist column data
tfree
(
pDataCol
->
pData
);
}
TSDB_WUNLOCK_TABLE
(
pTable
);
tfree
(
oldLastCols
);
return
0
;
return
0
;
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录