//===----------------------------------------------------------------------===// // DuckDB // // duckdb/storage/table/list_column_data.hpp // // //===----------------------------------------------------------------------===// #pragma once #include "duckdb/storage/table/column_data.hpp" #include "duckdb/storage/table/validity_column_data.hpp" namespace duckdb { //! List column data represents a list class ListColumnData : public ColumnData { public: ListColumnData(BlockManager &block_manager, DataTableInfo &info, idx_t column_index, idx_t start_row, LogicalType type, optional_ptr parent = nullptr); //! The child-column of the list unique_ptr child_column; //! The validity column data of the struct ValidityColumnData validity; public: void SetStart(idx_t new_start) override; bool CheckZonemap(ColumnScanState &state, TableFilter &filter) override; void InitializeScan(ColumnScanState &state) override; void InitializeScanWithOffset(ColumnScanState &state, idx_t row_idx) override; idx_t Scan(TransactionData transaction, idx_t vector_index, ColumnScanState &state, Vector &result) override; idx_t ScanCommitted(idx_t vector_index, ColumnScanState &state, Vector &result, bool allow_updates) override; idx_t ScanCount(ColumnScanState &state, Vector &result, idx_t count) override; void Skip(ColumnScanState &state, idx_t count = STANDARD_VECTOR_SIZE) override; void InitializeAppend(ColumnAppendState &state) override; void Append(BaseStatistics &stats, ColumnAppendState &state, Vector &vector, idx_t count) override; void RevertAppend(row_t start_row) override; idx_t Fetch(ColumnScanState &state, row_t row_id, Vector &result) override; void FetchRow(TransactionData transaction, ColumnFetchState &state, row_t row_id, Vector &result, idx_t result_idx) override; void Update(TransactionData transaction, idx_t column_index, Vector &update_vector, row_t *row_ids, idx_t update_count) override; void UpdateColumn(TransactionData transaction, const vector &column_path, Vector &update_vector, row_t *row_ids, idx_t update_count, idx_t depth) override; unique_ptr GetUpdateStatistics() override; void CommitDropColumn() override; unique_ptr CreateCheckpointState(RowGroup &row_group, PartialBlockManager &partial_block_manager) override; unique_ptr Checkpoint(RowGroup &row_group, PartialBlockManager &partial_block_manager, ColumnCheckpointInfo &checkpoint_info) override; void DeserializeColumn(Deserializer &source) override; void GetColumnSegmentInfo(duckdb::idx_t row_group_index, vector col_path, vector &result) override; private: uint64_t FetchListOffset(idx_t row_idx); }; } // namespace duckdb