2019-02-19 18:41:18 +00:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <string>
|
|
|
|
#include <Core/Block.h>
|
|
|
|
#include <Processors/Formats/IOutputFormat.h>
|
|
|
|
#include <Formats/FormatSettings.h>
|
|
|
|
|
|
|
|
|
|
|
|
namespace DB
|
|
|
|
{
|
|
|
|
class WriteBuffer;
|
|
|
|
|
|
|
|
|
|
|
|
/** A data format designed to simplify the implementation of the ODBC driver.
|
|
|
|
* ODBC driver is designed to be build for different platforms without dependencies from the main code,
|
|
|
|
* so the format is made that way so that it can be as easy as possible to parse it.
|
|
|
|
* A header is displayed with the required information.
|
|
|
|
* The data is then output in the order of the rows. Each value is displayed as follows: length in Int32 format (-1 for NULL), then data in text form.
|
|
|
|
*/
|
|
|
|
class ODBCDriver2BlockOutputFormat final : public IOutputFormat
|
|
|
|
{
|
|
|
|
public:
|
2019-08-03 11:02:40 +00:00
|
|
|
ODBCDriver2BlockOutputFormat(WriteBuffer & out_, const Block & header_, const FormatSettings & format_settings_);
|
2019-02-19 18:41:18 +00:00
|
|
|
|
|
|
|
String getName() const override { return "ODBCDriver2BlockOutputFormat"; }
|
|
|
|
|
|
|
|
std::string getContentType() const override
|
|
|
|
{
|
|
|
|
return "application/octet-stream";
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
2021-11-02 13:40:41 +00:00
|
|
|
void consume(Chunk) override;
|
|
|
|
void consumeTotals(Chunk) override;
|
|
|
|
void writePrefix() override;
|
2019-02-19 18:41:18 +00:00
|
|
|
|
2021-11-02 13:40:41 +00:00
|
|
|
const FormatSettings format_settings;
|
2019-02-19 18:41:18 +00:00
|
|
|
|
2021-03-09 14:46:52 +00:00
|
|
|
void writeRow(const Serializations & serializations, const Columns & columns, size_t row_idx, std::string & buffer);
|
2019-02-19 18:41:18 +00:00
|
|
|
void write(Chunk chunk, PortKind port_kind);
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
}
|