From dbf320bd64112435d08c417e26cb7323dc01920d Mon Sep 17 00:00:00 2001 From: shen yushi Date: Tue, 26 Dec 2023 19:27:37 +0800 Subject: [PATCH] Fix bug. fix materialize sink bug. (#379) --- .gitignore | 8 +++++- src/executor/operator/physical_sink.cpp | 25 +++++++++++++++---- src/storage/meta/entry/block_column_entry.cpp | 1 - 3 files changed, 27 insertions(+), 7 deletions(-) diff --git a/.gitignore b/.gitignore index 71934cd5d6..defa5f2a45 100644 --- a/.gitignore +++ b/.gitignore @@ -107,4 +107,10 @@ sift_1m test/data/benchmark/* # ignore valgrind output file -callgrind.out.* \ No newline at end of file +callgrind.out.* + +# ignore vscode config file +.vscode/ + +# ignore vscode clangd cache file +.cache/ \ No newline at end of file diff --git a/src/executor/operator/physical_sink.cpp b/src/executor/operator/physical_sink.cpp index 9b67722202..6c44160b0c 100644 --- a/src/executor/operator/physical_sink.cpp +++ b/src/executor/operator/physical_sink.cpp @@ -81,7 +81,10 @@ void PhysicalSink::FillSinkStateFromLastOperatorState(MaterializeSinkState *mate } case PhysicalOperatorType::kShow: { ShowOperatorState *show_output_state = static_cast(task_op_state); - materialize_sink_state->data_block_array_ = Move(show_output_state->output_); + for (auto &data_block : show_output_state->output_) { + materialize_sink_state->data_block_array_.emplace_back(Move(data_block)); + } + show_output_state->output_.clear(); break; } case PhysicalOperatorType::kExplain: { @@ -90,7 +93,10 @@ void PhysicalSink::FillSinkStateFromLastOperatorState(MaterializeSinkState *mate Error("Empty explain output"); } - materialize_sink_state->data_block_array_ = Move(explain_output_state->data_block_array_); + for (auto &data_block : explain_output_state->data_block_array_) { + materialize_sink_state->data_block_array_.emplace_back(Move(data_block)); + } + explain_output_state->data_block_array_.clear(); break; } case PhysicalOperatorType::kProjection: { @@ -102,7 +108,10 @@ void PhysicalSink::FillSinkStateFromLastOperatorState(MaterializeSinkState *mate Error("Empty projection output"); } } else { - materialize_sink_state->data_block_array_ = Move(projection_output_state->data_block_array_); + for (auto &data_block : projection_output_state->data_block_array_) { + materialize_sink_state->data_block_array_.emplace_back(Move(data_block)); + } + projection_output_state->data_block_array_.clear(); } break; } @@ -115,7 +124,10 @@ void PhysicalSink::FillSinkStateFromLastOperatorState(MaterializeSinkState *mate Error("Empty sort output"); } } else { - materialize_sink_state->data_block_array_ = Move(sort_output_state->data_block_array_); + for (auto &data_block : sort_output_state->data_block_array_) { + materialize_sink_state->data_block_array_.emplace_back(Move(data_block)); + } + sort_output_state->data_block_array_.clear(); } break; } @@ -126,7 +138,10 @@ void PhysicalSink::FillSinkStateFromLastOperatorState(MaterializeSinkState *mate Error("Empty knn scan output"); } - materialize_sink_state->data_block_array_ = Move(knn_output_state->data_block_array_); + for (auto &data_block : knn_output_state->data_block_array_) { + materialize_sink_state->data_block_array_.emplace_back(Move(data_block)); + } + knn_output_state->data_block_array_.clear(); break; } default: { diff --git a/src/storage/meta/entry/block_column_entry.cpp b/src/storage/meta/entry/block_column_entry.cpp index 99879b5ce3..ea1cf02f63 100644 --- a/src/storage/meta/entry/block_column_entry.cpp +++ b/src/storage/meta/entry/block_column_entry.cpp @@ -208,7 +208,6 @@ void BlockColumnEntry::Flush(BlockColumnEntry *block_column_entry, SizeT) { // SizeT buffer_size = row_count * column_type->Size(); if (block_column_entry->buffer_->Save()) { block_column_entry->buffer_->Sync(); - LOG_WARN(Format("Close file {}", block_column_entry->FilePath())); block_column_entry->buffer_->CloseFile(); }