20static void runCreateHyperFileFromCSV() {
21 std::cout <<
"EXAMPLE - Load data from CSV into table in new Hyper file" << std::endl;
22 const std::string pathToDatabase =
"data/customer.hyper";
29 std::unordered_map<std::string, std::string> processParameters = {
31 {
"log_file_max_count",
"2"},
33 {
"log_file_size_limit",
"100M"}};
41 std::unordered_map<std::string, std::string> connectionParameters = {{
"lc_time",
"en_US"}};
49 std::string pathToCSV =
"data/customers.csv";
63 std::cout <<
"Issuing the SQL COPY command to load the csv file into the table. Since the first line" << std::endl;
64 std::cout <<
"of our csv file contains the column names, we use the `header` option to skip it." << std::endl;
65 int64_t rowCount = connection.executeCommand(
67 " with (format csv, NULL 'NULL', delimiter ',', header)");
69 std::cout <<
"The number of rows in table " << customerTable.
getTableName() <<
" is " << rowCount <<
"." << std::endl;
71 std::cout <<
"The connection to the Hyper file has been closed." << std::endl;
73 std::cout <<
"The Hyper Process has been shut down." << std::endl;
78 runCreateHyperFileFromCSV();
80 std::cout << e.
toString() << std::endl;
The catalog class gives access to the metadata of the attached databases of a connection.
void createTable(const hyperapi::TableDefinition &table_definition) const
Creates a SQL table with the given table definition.
Defines a Hyper connection.
Defines an exception object that is thrown on failure by the functions in the Hyper API C++ library.
std::string toString() const
Returns a formatted string containing the message and hint of the error and all causes.
static SqlType bigInt() noexcept
Returns the BIG INTEGER SQL type.
static SqlType text() noexcept
Returns the TEXT SQL type.
A Column of a table definition.
const TableName & getTableName() const noexcept
Returns the name of the table.
std::string toString() const
The main header of the Hyper API for C++.
@ NotNullable
The column cannot contain NULL values.
@ SendUsageDataToTableau
Telemetry data will be sent to tableau to help improve the Hyper API.
@ CreateAndReplace
Create the database. If it already exists, drop the old one first.
std::string escapeStringLiteral(string_view input)
Escapes the given string for safe usage in SQL query or command strings as a string literal.