Connect an application
This page documents the preview version (v2.21). Preview includes features under active development and is for development and testing only. For production, use the stable version (v2024.1). To learn more, see Versioning.
Prerequisites
The tutorial assumes that you have:
- installed YugabyteDB, and created a universe with YSQL enabled. If not, please follow the steps in Quick start.
- have a 32-bit (x86) or 64-bit (x64) architecture machine.
- have
gcc
4.1.2 or later, clang 3.4 or later installed.
Install the libpqxx driver
Download the source from the libpqxx and build the binaries as follows. If needed, detailed steps are provided in the README file.
Get the source
$ git clone https://github.com/jtv/libpqxx.git
Dependencies
Note that this package depends on PostgreSQL binaries. Make sure that the PostgreSQL bin
directory is on the command path.
export PATH=$PATH:<yugabyte-install-dir>/postgres/bin
Build and install
$ cd libpqxx
$ ./configure
$ make
$ make install
Create a sample C++ application
Add the C++ code
Create a file ybsql_hello_world.cpp
and copy the contents below:
#include <iostream>
#include <pqxx/pqxx>
int main(int, char *argv[])
{
pqxx::connection c("host=127.0.0.1 port=5433 dbname=yugabyte user=yugabyte password=yugabyte");
pqxx::work txn(c);
pqxx::result r;
/* Create table */
try
{
r = txn.exec("CREATE TABLE employee (id int PRIMARY KEY, \
name varchar, age int, \
language varchar)");
}
catch (const std::exception &e)
{
std::cerr << e.what() << std::endl;
return 1;
}
std::cout << "Created table employee\n";
/* Insert a row */
try
{
r = txn.exec("INSERT INTO employee (id, name, age, language) \
VALUES (1, 'John', 35, 'C++')");
}
catch (const std::exception &e)
{
std::cerr << e.what() << std::endl;
return 1;
}
std::cout << "Inserted data (1, 'John', 35, 'C++')\n";
/* Query the row */
try
{
r = txn.exec("SELECT name, age, language FROM employee WHERE id = 1");
for (auto row: r)
std::cout << "Query returned: "
<< row["name"].c_str() << ", "
<< row["age"].as<int>() << ", "
<< row["language"].c_str() << std::endl;
}
catch (const std::exception &e)
{
std::cerr << e.what() << std::endl;
return 1;
}
txn.commit();
return 0;
}
Run the application
You can compile the file using gcc
or clang
. Note that C++ 11 is the minimum supported C++ version. Make sure your compiler supports this, and if necessary, that you have support for C++11 configured. For gcc
, run the following command:
$ g++ -std=c++11 ybsql_hello_world.cpp -lpqxx -lpq -I<yugabyte-install-dir>/postgres/include -o ybsql_hello_world
Use the application by running the following command:
$ ./ybsql_hello_world
You should see the following output:
Created table employee
Inserted data (1, 'John', 35, 'C++')
Query returned: John, 35, C++