2018-04-19 10:33:16 +00:00
|
|
|
#include <Storages/MergeTree/ReplicatedMergeTreeMutationEntry.h>
|
|
|
|
#include <IO/Operators.h>
|
|
|
|
#include <IO/ReadBufferFromString.h>
|
|
|
|
#include <IO/WriteBufferFromString.h>
|
2020-03-13 17:23:36 +00:00
|
|
|
#include <IO/ReadHelpers.h>
|
2022-07-05 07:39:52 +00:00
|
|
|
#include <Backups/BackupEntryFromMemory.h>
|
2018-04-19 10:33:16 +00:00
|
|
|
|
|
|
|
|
|
|
|
namespace DB
|
|
|
|
{
|
|
|
|
|
|
|
|
void ReplicatedMergeTreeMutationEntry::writeText(WriteBuffer & out) const
|
|
|
|
{
|
|
|
|
out << "format version: 1\n"
|
|
|
|
<< "create time: " << LocalDateTime(create_time ? create_time : time(nullptr)) << "\n"
|
|
|
|
<< "source replica: " << source_replica << "\n"
|
|
|
|
<< "block numbers count: " << block_numbers.size() << "\n";
|
|
|
|
|
|
|
|
for (const auto & kv : block_numbers)
|
|
|
|
{
|
|
|
|
const String & partition_id = kv.first;
|
|
|
|
Int64 number = kv.second;
|
|
|
|
out << partition_id << "\t" << number << "\n";
|
|
|
|
}
|
|
|
|
|
2018-07-11 12:43:55 +00:00
|
|
|
out << "commands: ";
|
|
|
|
commands.writeText(out);
|
2020-01-31 19:30:33 +00:00
|
|
|
out << "\n";
|
|
|
|
|
|
|
|
out << "alter version: ";
|
|
|
|
out << alter_version;
|
|
|
|
|
2018-04-19 10:33:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void ReplicatedMergeTreeMutationEntry::readText(ReadBuffer & in)
|
|
|
|
{
|
|
|
|
in >> "format version: 1\n";
|
|
|
|
|
|
|
|
LocalDateTime create_time_dt;
|
|
|
|
in >> "create time: " >> create_time_dt >> "\n";
|
2021-03-15 19:23:27 +00:00
|
|
|
create_time = DateLUT::instance().makeDateTime(
|
|
|
|
create_time_dt.year(), create_time_dt.month(), create_time_dt.day(),
|
|
|
|
create_time_dt.hour(), create_time_dt.minute(), create_time_dt.second());
|
2018-04-19 10:33:16 +00:00
|
|
|
|
|
|
|
in >> "source replica: " >> source_replica >> "\n";
|
|
|
|
|
|
|
|
size_t count;
|
|
|
|
in >> "block numbers count: " >> count >> "\n";
|
|
|
|
for (size_t i = 0; i < count; ++i)
|
|
|
|
{
|
|
|
|
String partition_id;
|
|
|
|
Int64 number;
|
|
|
|
in >> partition_id >> "\t" >> number >> "\n";
|
|
|
|
block_numbers[partition_id] = number;
|
|
|
|
}
|
|
|
|
|
2018-07-11 12:43:55 +00:00
|
|
|
in >> "commands: ";
|
|
|
|
commands.readText(in);
|
2020-03-13 17:23:36 +00:00
|
|
|
if (checkString("\nalter version: ", in))
|
|
|
|
in >> alter_version;
|
2018-04-19 10:33:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
String ReplicatedMergeTreeMutationEntry::toString() const
|
|
|
|
{
|
|
|
|
WriteBufferFromOwnString out;
|
|
|
|
writeText(out);
|
|
|
|
return out.str();
|
|
|
|
}
|
|
|
|
|
2018-04-19 14:20:18 +00:00
|
|
|
ReplicatedMergeTreeMutationEntry ReplicatedMergeTreeMutationEntry::parse(const String & str, String znode_name)
|
2018-04-19 10:33:16 +00:00
|
|
|
{
|
|
|
|
ReplicatedMergeTreeMutationEntry res;
|
2018-04-19 14:20:18 +00:00
|
|
|
res.znode_name = std::move(znode_name);
|
|
|
|
|
|
|
|
ReadBufferFromString in(str);
|
2018-04-19 10:33:16 +00:00
|
|
|
res.readText(in);
|
|
|
|
assertEOF(in);
|
2018-04-19 14:20:18 +00:00
|
|
|
|
2018-04-19 10:33:16 +00:00
|
|
|
return res;
|
|
|
|
}
|
|
|
|
|
2022-07-05 07:39:52 +00:00
|
|
|
|
|
|
|
std::shared_ptr<const IBackupEntry> ReplicatedMergeTreeMutationEntry::backup() const
|
|
|
|
{
|
|
|
|
WriteBufferFromOwnString out;
|
|
|
|
out << "block numbers count: " << block_numbers.size() << "\n";
|
|
|
|
|
|
|
|
for (const auto & kv : block_numbers)
|
|
|
|
{
|
|
|
|
const String & partition_id = kv.first;
|
|
|
|
Int64 number = kv.second;
|
|
|
|
out << partition_id << "\t" << number << "\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
out << "commands: ";
|
|
|
|
commands.writeText(out);
|
|
|
|
out << "\n";
|
|
|
|
|
|
|
|
return std::make_shared<BackupEntryFromMemory>(out.str());
|
|
|
|
}
|
|
|
|
|
2018-04-19 10:33:16 +00:00
|
|
|
}
|