CreateTable.cpp 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  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. namespace SQL::AST {
  9. RefPtr<SQLResult> CreateTable::execute(ExecutionContext& context) const
  10. {
  11. auto schema_name = (!m_schema_name.is_null() && !m_schema_name.is_empty()) ? m_schema_name : "default";
  12. auto schema_def = context.database->get_schema(schema_name);
  13. if (!schema_def)
  14. return SQLResult::construct(SQLCommand::Create, SQLErrorCode::SchemaDoesNotExist, m_schema_name);
  15. auto table_def = context.database->get_table(schema_name, m_table_name);
  16. if (table_def) {
  17. if (m_is_error_if_table_exists) {
  18. return SQLResult::construct(SQLCommand::Create, SQLErrorCode::TableExists, m_table_name);
  19. } else {
  20. return SQLResult::construct(SQLCommand::Create);
  21. }
  22. }
  23. table_def = TableDef::construct(schema_def, m_table_name);
  24. for (auto& column : m_columns) {
  25. SQLType type;
  26. if (column.type_name()->name() == "VARCHAR" || column.type_name()->name() == "TEXT") {
  27. type = SQLType::Text;
  28. } else if (column.type_name()->name() == "INT" || column.type_name()->name() == "INTEGER") {
  29. type = SQLType::Integer;
  30. } else if (column.type_name()->name() == "FLOAT" || column.type_name()->name() == "NUMBER") {
  31. type = SQLType::Float;
  32. } else {
  33. return SQLResult::construct(SQLCommand::Create, SQLErrorCode::InvalidType, column.type_name()->name());
  34. }
  35. table_def->append_column(column.name(), type);
  36. }
  37. context.database->add_table(*table_def);
  38. return SQLResult::construct(SQLCommand::Create, 0, 1);
  39. }
  40. }