Describe.cpp 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. /*
  2. * Copyright (c) 2021, Mahmoud Mandour <ma.mandourr@gmail.com>
  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. Result DescribeTable::execute(ExecutionContext& context) const
  12. {
  13. auto schema_name = m_qualified_table_name->schema_name();
  14. auto table_name = m_qualified_table_name->table_name();
  15. auto table_def = TRY(context.database->get_table(schema_name, table_name));
  16. if (!table_def) {
  17. if (schema_name.is_empty())
  18. schema_name = "default"sv;
  19. return { SQLCommand::Describe, SQLErrorCode::TableDoesNotExist, String::formatted("{}.{}", schema_name, table_name) };
  20. }
  21. auto describe_table_def = MUST(context.database->get_table("master"sv, "internal_describe_table"sv));
  22. auto descriptor = describe_table_def->to_tuple_descriptor();
  23. Result result { SQLCommand::Describe };
  24. for (auto& column : table_def->columns()) {
  25. Tuple tuple(descriptor);
  26. tuple[0] = column.name();
  27. tuple[1] = SQLType_name(column.type());
  28. result.insert(tuple, Tuple {});
  29. }
  30. return result;
  31. }
  32. }