This is an automated email from the ASF dual-hosted git repository.
eldenmoon pushed a commit to branch branch-2.0
in repository https://gitbox.apache.org/repos/asf/doris.git
The following commit(s) were added to refs/heads/branch-2.0 by this push:
new 5a3a9208820 [bugfix](topn) fix coredump in copy_column_data_to_block
when nullable mismatch
5a3a9208820 is described below
commit 5a3a9208820821c4437b19e0ced907f63399ad4f
Author: Kang <[email protected]>
AuthorDate: Wed Nov 29 19:43:03 2023 +0800
[bugfix](topn) fix coredump in copy_column_data_to_block when nullable
mismatch
return RuntimeError if copy_column_data_to_block nullable mismatch to avoid
coredump in input_col_ptr->filter_by_selector(sel_rowid_idx, select_size,
raw_res_ptr) .
The problem is reported by a doris user but I can not reproduce it, so
there is no testcase added currently.
---
be/src/vec/core/block.h | 6 ++++++
1 file changed, 6 insertions(+)
diff --git a/be/src/vec/core/block.h b/be/src/vec/core/block.h
index ebb0f6e23d9..939597d50b6 100644
--- a/be/src/vec/core/block.h
+++ b/be/src/vec/core/block.h
@@ -154,6 +154,12 @@ public:
reinterpret_cast<vectorized::ColumnNullable*>(raw_res_ptr.get());
col_ptr_nullable->get_null_map_column().insert_many_defaults(select_size);
raw_res_ptr = col_ptr_nullable->get_nested_column_ptr();
+ } else if (!raw_res_ptr->is_nullable() &&
input_col_ptr->is_nullable()) {
+ LOG(WARNING) << "nullable mismatch for raw_res_column: "
+ << this->get_by_position(block_cid).dump_structure()
+ << " input_column: " <<
input_col_ptr->dump_structure()
+ << " block_cid: " << block_cid << " select_size: " <<
select_size;
+ return Status::RuntimeError("copy_column_data_to_block nullable
mismatch");
}
return input_col_ptr->filter_by_selector(sel_rowid_idx, select_size,
raw_res_ptr);
---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]