|
@@ -14,22 +14,36 @@ namespace SQL::AST {
|
|
RefPtr<SQLResult> Select::execute(ExecutionContext& context) const
|
|
RefPtr<SQLResult> Select::execute(ExecutionContext& context) const
|
|
{
|
|
{
|
|
if (table_or_subquery_list().size() == 1 && table_or_subquery_list()[0].is_table()) {
|
|
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<ResultColumn> columns;
|
|
if (result_column_list().size() == 1 && result_column_list()[0].type() == ResultType::All) {
|
|
if (result_column_list().size() == 1 && result_column_list()[0].type() == ResultType::All) {
|
|
- 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());
|
|
|
|
|
|
+ for (auto& col : table->columns()) {
|
|
|
|
+ columns.append(
|
|
|
|
+ create_ast_node<ResultColumn>(
|
|
|
|
+ create_ast_node<ColumnNameExpression>(table->parent()->name(), table->name(), col.name()),
|
|
|
|
+ ""));
|
|
}
|
|
}
|
|
- NonnullRefPtr<TupleDescriptor> descriptor = table->to_tuple_descriptor();
|
|
|
|
- context.result = SQLResult::construct();
|
|
|
|
- for (auto& row : context.database->select_all(*table)) {
|
|
|
|
- Tuple tuple(descriptor);
|
|
|
|
- for (auto ix = 0u; ix < descriptor->size(); ix++) {
|
|
|
|
- tuple[ix] = row[ix];
|
|
|
|
- }
|
|
|
|
- context.result->append(tuple);
|
|
|
|
|
|
+ } else {
|
|
|
|
+ for (auto& col : result_column_list()) {
|
|
|
|
+ columns.append(col);
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ context.result = SQLResult::construct();
|
|
|
|
+ AK::NonnullRefPtr<TupleDescriptor> 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);
|
|
}
|
|
}
|
|
- return context.result;
|
|
|
|
|
|
+ context.result->append(tuple);
|
|
}
|
|
}
|
|
|
|
+ return context.result;
|
|
}
|
|
}
|
|
return SQLResult::construct();
|
|
return SQLResult::construct();
|
|
}
|
|
}
|