ClickHouse/src/Storages/StorageNull.cpp

79 lines
2.6 KiB
C++
Raw Normal View History

#include <Storages/StorageNull.h>
#include <Storages/StorageFactory.h>
2018-12-25 23:18:07 +00:00
#include <Storages/AlterCommands.h>
2018-01-11 19:13:19 +00:00
#include <Interpreters/InterpreterAlterQuery.h>
#include <Interpreters/Context.h>
2018-01-11 19:13:19 +00:00
#include <Databases/IDatabase.h>
#include <IO/WriteHelpers.h>
namespace DB
{
namespace ErrorCodes
{
2020-02-25 18:02:41 +00:00
extern const int NOT_IMPLEMENTED;
extern const int NUMBER_OF_ARGUMENTS_DOESNT_MATCH;
extern const int ALTER_OF_COLUMN_IS_FORBIDDEN;
}
void registerStorageNull(StorageFactory & factory)
{
factory.registerStorage("Null", [](const StorageFactory::Arguments & args)
{
if (!args.engine_args.empty())
throw Exception(ErrorCodes::NUMBER_OF_ARGUMENTS_DOESNT_MATCH, "Engine {} doesn't support any arguments ({} given)",
args.engine_name, args.engine_args.size());
return std::make_shared<StorageNull>(args.table_id, args.columns, args.constraints, args.comment);
},
{
.supports_parallel_insert = true,
});
}
void StorageNull::checkAlterIsPossible(const AlterCommands & commands, ContextPtr context) const
2019-12-26 18:17:05 +00:00
{
2023-03-27 15:38:52 +00:00
std::optional<NameDependencies> name_deps{};
2019-12-26 18:17:05 +00:00
for (const auto & command : commands)
{
2021-09-06 15:59:46 +00:00
if (command.type != AlterCommand::Type::ADD_COLUMN
&& command.type != AlterCommand::Type::MODIFY_COLUMN
2021-09-06 15:59:46 +00:00
&& command.type != AlterCommand::Type::DROP_COLUMN
&& command.type != AlterCommand::Type::COMMENT_COLUMN
&& command.type != AlterCommand::Type::COMMENT_TABLE)
throw Exception(ErrorCodes::NOT_IMPLEMENTED, "Alter of type '{}' is not supported by storage {}",
command.type, getName());
if (command.type == AlterCommand::DROP_COLUMN && !command.clear)
{
2023-03-27 15:38:52 +00:00
if (!name_deps)
name_deps = getDependentViewsByColumn(context);
const auto & deps_mv = name_deps.value()[command.column_name];
if (!deps_mv.empty())
{
2023-01-17 00:19:44 +00:00
throw Exception(ErrorCodes::ALTER_OF_COLUMN_IS_FORBIDDEN,
"Trying to ALTER DROP column {} which is referenced by materialized view {}",
backQuoteIfNeed(command.column_name), toString(deps_mv)
);
}
}
2019-12-26 18:17:05 +00:00
}
}
2021-10-25 17:49:49 +00:00
void StorageNull::alter(const AlterCommands & params, ContextPtr context, AlterLockHolder &)
2018-01-11 19:13:19 +00:00
{
2019-12-03 16:25:32 +00:00
auto table_id = getStorageID();
2020-06-09 17:28:29 +00:00
StorageInMemoryMetadata new_metadata = getInMemoryMetadata();
params.apply(new_metadata, context);
DatabaseCatalog::instance().getDatabase(table_id.database_name)->alterTable(context, table_id, new_metadata);
setInMemoryMetadata(new_metadata);
2018-01-11 19:13:19 +00:00
}
}