ClickHouse/dbms/src/Storages/StorageNull.cpp

48 lines
1.5 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 <Databases/IDatabase.h>
#include <IO/WriteHelpers.h>
namespace DB
{
namespace ErrorCodes
{
extern const int NUMBER_OF_ARGUMENTS_DOESNT_MATCH;
}
void registerStorageNull(StorageFactory & factory)
{
factory.registerStorage("Null", [](const StorageFactory::Arguments & args)
{
if (!args.engine_args.empty())
throw Exception(
"Engine " + args.engine_name + " doesn't support any arguments (" + toString(args.engine_args.size()) + " given)",
ErrorCodes::NUMBER_OF_ARGUMENTS_DOESNT_MATCH);
return StorageNull::create(args.database_name, args.table_name, args.columns);
});
}
2019-03-05 10:12:20 +00:00
void StorageNull::alter(
const AlterCommands & params, const String & current_database_name, const String & current_table_name,
2019-03-07 20:52:25 +00:00
const Context & context, TableStructureWriteLockHolder & table_lock_holder)
2018-01-11 19:13:19 +00:00
{
2019-03-07 20:52:25 +00:00
lockStructureExclusively(table_lock_holder, context.getCurrentQueryId());
2018-01-11 19:13:19 +00:00
ColumnsDescription new_columns = getColumns();
2019-05-02 16:07:23 +00:00
IndicesDescription new_indices = getIndices();
ConstraintsDescription new_constraints = getConstraints();
2019-07-24 12:56:39 +00:00
params.applyForColumnsOnly(new_columns);
context.getDatabase(current_database_name)->alterTable(context, current_table_name, new_columns, new_indices, new_constraints, {});
setColumns(std::move(new_columns));
2018-01-11 19:13:19 +00:00
}
}