Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
2dot5
ClickHouse
提交
be68461f
C
ClickHouse
项目概览
2dot5
/
ClickHouse
通知
3
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
C
ClickHouse
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
be68461f
编写于
6月 22, 2015
作者:
A
Andrey Mironov
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
dbms: correctly determine mark to end of previous block [#MTRSADMIN-1093]
上级
978aba0f
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
23 addition
and
0 deletion
+23
-0
dbms/src/Storages/MergeTree/MergeTreePartChecker.cpp
dbms/src/Storages/MergeTree/MergeTreePartChecker.cpp
+23
-0
未找到文件。
dbms/src/Storages/MergeTree/MergeTreePartChecker.cpp
浏览文件 @
be68461f
...
...
@@ -11,6 +11,7 @@
#include <DB/IO/CompressedReadBuffer.h>
#include <DB/IO/HashingReadBuffer.h>
#include <DB/Columns/ColumnsNumber.h>
#include <statdaemons/ext/scope_guard.hpp>
namespace
DB
...
...
@@ -115,6 +116,12 @@ struct Stream
readIntBinary
(
mrk_mark
.
offset_in_compressed_file
,
mrk_hashing_buf
);
readIntBinary
(
mrk_mark
.
offset_in_decompressed_block
,
mrk_hashing_buf
);
/// На всякий случай, сохраним смещение в файле и размер предыдущего блока.
SCOPE_EXIT
(
prev_offset_in_compressed_file
=
mrk_mark
.
offset_in_compressed_file
;
prev_buffer_size
=
uncompressed_hashing_buf
.
buffer
().
size
();
);
bool
has_alternative_mark
=
false
;
MarkInCompressedFile
alternative_data_mark
;
MarkInCompressedFile
data_mark
;
...
...
@@ -138,6 +145,18 @@ struct Stream
if
(
uncompressed_hashing_buf
.
eof
())
return
;
}
else
if
(
uncompressed_hashing_buf
.
offset
()
==
0
)
{
/// Восстановим засечку на конец предыдущего блока по сохраненным данным
has_alternative_mark
=
true
;
alternative_data_mark
.
offset_in_compressed_file
=
prev_offset_in_compressed_file
;
alternative_data_mark
.
offset_in_decompressed_block
=
prev_buffer_size
;
if
(
mrk_mark
==
alternative_data_mark
)
return
;
}
std
::
cout
<<
"mrk_mark "
<<
mrk_mark
.
offset_in_compressed_file
<<
' '
<<
mrk_mark
.
offset_in_decompressed_block
<<
std
::
endl
;
data_mark
.
offset_in_compressed_file
=
compressed_hashing_buf
.
count
()
-
uncompressing_buf
.
getSizeCompressed
();
data_mark
.
offset_in_decompressed_block
=
uncompressed_hashing_buf
.
offset
();
...
...
@@ -161,6 +180,10 @@ struct Stream
checksums
.
files
[
name
+
".mrk"
]
=
MergeTreeData
::
DataPart
::
Checksums
::
Checksum
(
mrk_hashing_buf
.
count
(),
mrk_hashing_buf
.
getHash
());
}
private:
size_t
prev_offset_in_compressed_file
{};
size_t
prev_buffer_size
{};
};
/// Возвращает количество строк. Добавляет в checksums чексуммы всех файлов столбца.
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录