//===----------------------------------------------------------------------===// // DuckDB // // duckdb/execution/operator/persistent/physical_delete.hpp // // //===----------------------------------------------------------------------===// #pragma once #include "duckdb/execution/physical_operator.hpp" namespace duckdb { class DataTable; //! Physically delete data from a table class PhysicalDelete : public PhysicalOperator { public: static constexpr const PhysicalOperatorType TYPE = PhysicalOperatorType::DELETE_OPERATOR; public: PhysicalDelete(vector types, TableCatalogEntry &tableref, DataTable &table, idx_t row_id_index, idx_t estimated_cardinality, bool return_chunk) : PhysicalOperator(PhysicalOperatorType::DELETE_OPERATOR, std::move(types), estimated_cardinality), tableref(tableref), table(table), row_id_index(row_id_index), return_chunk(return_chunk) { } TableCatalogEntry &tableref; DataTable &table; idx_t row_id_index; bool return_chunk; public: // Source interface unique_ptr GetGlobalSourceState(ClientContext &context) const override; SourceResultType GetData(ExecutionContext &context, DataChunk &chunk, OperatorSourceInput &input) const override; bool IsSource() const override { return true; } public: // Sink interface unique_ptr GetGlobalSinkState(ClientContext &context) const override; unique_ptr GetLocalSinkState(ExecutionContext &context) const override; SinkResultType Sink(ExecutionContext &context, DataChunk &chunk, OperatorSinkInput &input) const override; bool IsSink() const override { return true; } bool ParallelSink() const override { return true; } }; } // namespace duckdb