2019-08-09 15:58:07 +00:00
|
|
|
#include <IO/WriteHelpers.h>
|
2021-11-24 19:26:38 +00:00
|
|
|
#include <IO/WriteBufferFromString.h>
|
2019-08-09 15:58:07 +00:00
|
|
|
#include <Processors/Formats/Impl/JSONEachRowWithProgressRowOutputFormat.h>
|
|
|
|
#include <Formats/FormatFactory.h>
|
|
|
|
|
|
|
|
namespace DB
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
void JSONEachRowWithProgressRowOutputFormat::writeRowStartDelimiter()
|
|
|
|
{
|
2021-11-24 19:26:38 +00:00
|
|
|
if (has_progress)
|
|
|
|
writeProgress();
|
2022-09-01 19:00:24 +00:00
|
|
|
writeCString("{\"row\":{", *ostr);
|
2019-08-09 15:58:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void JSONEachRowWithProgressRowOutputFormat::writeRowEndDelimiter()
|
|
|
|
{
|
2022-09-01 19:00:24 +00:00
|
|
|
writeCString("}}\n", *ostr);
|
2019-08-09 15:58:07 +00:00
|
|
|
field_number = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
void JSONEachRowWithProgressRowOutputFormat::onProgress(const Progress & value)
|
|
|
|
{
|
|
|
|
progress.incrementPiecewiseAtomically(value);
|
2021-11-24 19:26:38 +00:00
|
|
|
String progress_line;
|
2022-09-01 19:00:24 +00:00
|
|
|
WriteBufferFromString buf(progress_line);
|
|
|
|
writeCString("{\"progress\":", buf);
|
|
|
|
progress.writeJSON(buf);
|
|
|
|
writeCString("}\n", buf);
|
|
|
|
buf.finalize();
|
2021-11-24 19:26:38 +00:00
|
|
|
std::lock_guard lock(progress_lines_mutex);
|
|
|
|
progress_lines.emplace_back(std::move(progress_line));
|
|
|
|
has_progress = true;
|
2019-08-09 15:58:07 +00:00
|
|
|
}
|
|
|
|
|
2021-11-24 19:26:38 +00:00
|
|
|
void JSONEachRowWithProgressRowOutputFormat::flush()
|
|
|
|
{
|
|
|
|
if (has_progress)
|
|
|
|
writeProgress();
|
2022-09-01 19:00:24 +00:00
|
|
|
JSONEachRowRowOutputFormat::flush();
|
2021-11-24 19:26:38 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void JSONEachRowWithProgressRowOutputFormat::writeSuffix()
|
|
|
|
{
|
|
|
|
if (has_progress)
|
|
|
|
writeProgress();
|
|
|
|
JSONEachRowRowOutputFormat::writeSuffix();
|
|
|
|
}
|
|
|
|
|
|
|
|
void JSONEachRowWithProgressRowOutputFormat::writeProgress()
|
|
|
|
{
|
|
|
|
std::lock_guard lock(progress_lines_mutex);
|
|
|
|
for (const auto & progress_line : progress_lines)
|
2022-09-01 19:00:24 +00:00
|
|
|
writeString(progress_line, *ostr);
|
2021-11-24 19:26:38 +00:00
|
|
|
progress_lines.clear();
|
|
|
|
has_progress = false;
|
|
|
|
}
|
2019-08-09 15:58:07 +00:00
|
|
|
|
2021-10-11 16:11:50 +00:00
|
|
|
void registerOutputFormatJSONEachRowWithProgress(FormatFactory & factory)
|
2019-08-09 15:58:07 +00:00
|
|
|
{
|
2021-10-11 16:11:50 +00:00
|
|
|
factory.registerOutputFormat("JSONEachRowWithProgress", [](
|
2019-08-09 15:58:07 +00:00
|
|
|
WriteBuffer & buf,
|
|
|
|
const Block & sample,
|
2020-10-06 12:47:52 +00:00
|
|
|
const RowOutputFormatParams & params,
|
2020-11-17 19:50:47 +00:00
|
|
|
const FormatSettings & _format_settings)
|
2019-08-09 15:58:07 +00:00
|
|
|
{
|
2020-11-17 19:50:47 +00:00
|
|
|
FormatSettings settings = _format_settings;
|
|
|
|
settings.json.serialize_as_strings = false;
|
|
|
|
return std::make_shared<JSONEachRowWithProgressRowOutputFormat>(buf,
|
|
|
|
sample, params, settings);
|
2020-09-02 04:05:02 +00:00
|
|
|
});
|
|
|
|
|
2021-10-11 16:11:50 +00:00
|
|
|
factory.registerOutputFormat("JSONStringsEachRowWithProgress", [](
|
2020-09-02 04:05:02 +00:00
|
|
|
WriteBuffer & buf,
|
|
|
|
const Block & sample,
|
2020-10-06 12:47:52 +00:00
|
|
|
const RowOutputFormatParams & params,
|
2020-11-17 19:50:47 +00:00
|
|
|
const FormatSettings & _format_settings)
|
2020-09-02 04:05:02 +00:00
|
|
|
{
|
2020-11-17 19:50:47 +00:00
|
|
|
FormatSettings settings = _format_settings;
|
|
|
|
settings.json.serialize_as_strings = true;
|
|
|
|
return std::make_shared<JSONEachRowWithProgressRowOutputFormat>(buf,
|
|
|
|
sample, params, settings);
|
2019-08-09 15:58:07 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|