/* * Copyright (c) 2021, Jan de Visser * * SPDX-License-Identifier: BSD-2-Clause */ #include #include #include #include namespace SQL::AST { RefPtr Select::execute(ExecutionContext& context) const { if (table_or_subquery_list().size() == 1 && table_or_subquery_list()[0].is_table()) { auto table = context.database->get_table(table_or_subquery_list()[0].schema_name(), table_or_subquery_list()[0].table_name()); if (!table) { return SQLResult::construct(SQL::SQLCommand::Select, SQL::SQLErrorCode::TableDoesNotExist, table_or_subquery_list()[0].table_name()); } NonnullRefPtrVector columns; if (result_column_list().size() == 1 && result_column_list()[0].type() == ResultType::All) { for (auto& col : table->columns()) { columns.append( create_ast_node( create_ast_node(table->parent()->name(), table->name(), col.name()), "")); } } else { for (auto& col : result_column_list()) { columns.append(col); } } context.result = SQLResult::construct(); AK::NonnullRefPtr descriptor = AK::adopt_ref(*new TupleDescriptor); for (auto& row : context.database->select_all(*table)) { context.current_row = &row; Tuple tuple(descriptor); for (auto& col : columns) { auto value = col.expression()->evaluate(context); tuple.append(value); } context.result->append(tuple); } return context.result; } return SQLResult::construct(); } }