Insert.cpp 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. /*
  2. * Copyright (c) 2021, Jan de Visser <jan@de-visser.net>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #include <LibSQL/AST/AST.h>
  7. #include <LibSQL/Database.h>
  8. #include <LibSQL/Meta.h>
  9. #include <LibSQL/Row.h>
  10. namespace SQL::AST {
  11. RefPtr<SQLResult> Insert::execute(ExecutionContext& context) const
  12. {
  13. auto table_def = context.database->get_table(m_schema_name, m_table_name);
  14. if (!table_def) {
  15. auto schema_name = m_schema_name;
  16. if (schema_name.is_null() || schema_name.is_empty())
  17. schema_name = "default";
  18. return SQLResult::construct(SQLCommand::Insert, SQLErrorCode::TableDoesNotExist, String::formatted("{}.{}", schema_name, m_table_name));
  19. }
  20. Row row(table_def);
  21. for (auto& column : m_column_names) {
  22. if (!row.has(column)) {
  23. return SQLResult::construct(SQLCommand::Insert, SQLErrorCode::ColumnDoesNotExist, column);
  24. }
  25. }
  26. for (auto& row_expr : m_chained_expressions) {
  27. for (auto& column_def : table_def->columns()) {
  28. if (!m_column_names.contains_slow(column_def.name())) {
  29. row[column_def.name()] = column_def.default_value();
  30. }
  31. }
  32. auto row_value = row_expr.evaluate(context);
  33. VERIFY(row_value.type() == SQLType::Tuple);
  34. auto values = row_value.to_vector().value();
  35. for (auto ix = 0u; ix < values.size(); ix++) {
  36. auto& column_name = m_column_names[ix];
  37. row[column_name] = values[ix];
  38. }
  39. context.database->insert(row);
  40. }
  41. return SQLResult::construct(SQLCommand::Insert, 0, m_chained_expressions.size(), 0);
  42. }
  43. }