PostgreSQL - C / C ++ Interface

Tutorial ini akan digunakan libpqxxlibrary, yang merupakan API klien C ++ resmi untuk PostgreSQL. Kode sumber libpqxx tersedia di bawah lisensi BSD, jadi Anda bebas mengunduhnya, menyebarkannya kepada orang lain, mengubahnya, menjualnya, memasukkannya ke dalam kode Anda sendiri, dan membagikan perubahan Anda dengan siapa pun yang Anda pilih.

Instalasi

Versi terbaru libpqxx tersedia untuk diunduh dari tautan Unduh Libpqxx . Jadi unduh versi terbaru dan ikuti langkah-langkah berikut -

wget http://pqxx.org/download/software/libpqxx/libpqxx-4.0.tar.gz
tar xvfz libpqxx-4.0.tar.gz
cd libpqxx-4.0
./configure
make
make install

Sebelum Anda mulai menggunakan antarmuka C / C ++ PostgreSQL, temukan file pg_hba.conf file di direktori instalasi PostgreSQL Anda dan tambahkan baris berikut -

# IPv4 local connections:
host    all         all         127.0.0.1/32          md5

Anda dapat memulai / memulai ulang server postgres jika tidak berjalan menggunakan perintah berikut -

[root@host]# service postgresql restart
Stopping postgresql service:                               [  OK  ]
Starting postgresql service:                               [  OK  ]

C / C ++ Interface API

Berikut ini adalah rutinitas antarmuka penting yang dapat mencukupi kebutuhan Anda untuk bekerja dengan database PostgreSQL dari program C / C ++ Anda. Jika Anda mencari aplikasi yang lebih canggih maka Anda dapat melihat dokumentasi resmi libpqxx, atau Anda dapat menggunakan API yang tersedia secara komersial.

No. S. API & Deskripsi
1

pqxx::connection C( const std::string & dbstring )

Ini adalah typedef yang akan digunakan untuk terhubung ke database. Di sini, dbstring menyediakan parameter yang diperlukan untuk terhubung ke database, misalnyadbname = testdb user = postgres password=pass123 hostaddr=127.0.0.1 port=5432.

Jika koneksi berhasil diatur maka itu membuat C dengan objek koneksi yang menyediakan berbagai fungsi fungsi publik yang berguna.

2

C.is_open()

Metode is_open () adalah metode publik dari objek koneksi dan mengembalikan nilai boolean. Jika koneksi aktif, maka metode ini mengembalikan nilai true jika tidak mengembalikan salah.

3

C.disconnect()

Metode ini digunakan untuk memutuskan koneksi database yang dibuka.

4

pqxx::work W( C )

Ini adalah typedef yang akan digunakan untuk membuat objek transaksional menggunakan koneksi C, yang pada akhirnya akan digunakan untuk mengeksekusi pernyataan SQL dalam mode transaksional.

Jika objek transaksi berhasil dibuat, maka itu ditugaskan ke variabel W yang akan digunakan untuk mengakses metode publik yang terkait dengan objek transaksional.

5

W.exec(const std::string & sql)

Metode publik dari objek transaksional ini akan digunakan untuk menjalankan pernyataan SQL.

6

W.commit()

Metode publik dari objek transaksional ini akan digunakan untuk melakukan transaksi.

7

W.abort()

Metode publik dari objek transaksional ini akan digunakan untuk mengembalikan transaksi.

8

pqxx::nontransaction N( C )

Ini adalah typedef yang akan digunakan untuk membuat objek non-transaksional menggunakan koneksi C, yang pada akhirnya akan digunakan untuk mengeksekusi pernyataan SQL dalam mode non-transaksional.

Jika objek transaksi berhasil dibuat, maka itu ditetapkan ke variabel N yang akan digunakan untuk mengakses metode publik yang terkait dengan objek non-transaksional.

9

N.exec(const std::string & sql)

Metode publik dari objek non-transaksional ini akan digunakan untuk mengeksekusi pernyataan SQL dan mengembalikan objek hasil yang sebenarnya merupakan interator yang memegang semua catatan yang dikembalikan.

Menghubungkan ke Database

Segmen kode C berikut menunjukkan cara menyambung ke database yang ada yang berjalan pada mesin lokal di port 5432. Di sini, saya menggunakan garis miring terbalik \ untuk kelanjutan baris.

#include <iostream>
#include <pqxx/pqxx> 

using namespace std;
using namespace pqxx;

int main(int argc, char* argv[]) {
   try {
      connection C("dbname = testdb user = postgres password = cohondob \
      hostaddr = 127.0.0.1 port = 5432");
      if (C.is_open()) {
         cout << "Opened database successfully: " << C.dbname() << endl;
      } else {
         cout << "Can't open database" << endl;
         return 1;
      }
      C.disconnect ();
   } catch (const std::exception &e) {
      cerr << e.what() << std::endl;
      return 1;
   }
}

Sekarang, mari kita kompilasi dan jalankan program di atas untuk terhubung ke database kita testdb, yang sudah tersedia di skema Anda dan dapat diakses menggunakan user postgres dan password pass123 .

Anda dapat menggunakan ID pengguna dan kata sandi berdasarkan pengaturan database Anda. Ingatlah untuk menyimpan -lpqxx dan -lpq dalam urutan yang ditentukan! Jika tidak, penaut akan mengeluh dengan getir tentang fungsi yang hilang dengan nama yang dimulai dengan "PQ".

$g++ test.cpp -lpqxx -lpq $./a.out
Opened database successfully: testdb

Buat Tabel

Segmen kode C berikut akan digunakan untuk membuat tabel di database yang dibuat sebelumnya -

#include <iostream>
#include <pqxx/pqxx> 

using namespace std;
using namespace pqxx;

int main(int argc, char* argv[]) {
   char * sql;
   
   try {
      connection C("dbname = testdb user = postgres password = cohondob \
      hostaddr = 127.0.0.1 port = 5432");
      if (C.is_open()) {
         cout << "Opened database successfully: " << C.dbname() << endl;
      } else {
         cout << "Can't open database" << endl;
         return 1;
      }

      /* Create SQL statement */
      sql = "CREATE TABLE COMPANY("  \
      "ID INT PRIMARY KEY     NOT NULL," \
      "NAME           TEXT    NOT NULL," \
      "AGE            INT     NOT NULL," \
      "ADDRESS        CHAR(50)," \
      "SALARY         REAL );";

      /* Create a transactional object. */
      work W(C);
      
      /* Execute SQL query */
      W.exec( sql );
      W.commit();
      cout << "Table created successfully" << endl;
      C.disconnect ();
   } catch (const std::exception &e) {
      cerr << e.what() << std::endl;
      return 1;
   }

   return 0;
}

Ketika program yang diberikan di atas dikompilasi dan dijalankan, itu akan membuat tabel PERUSAHAAN di database testdb Anda dan akan menampilkan pernyataan berikut -

Opened database successfully: testdb
Table created successfully

Operasi INSERT

Segmen kode C berikut menunjukkan bagaimana kita dapat membuat catatan dalam tabel PERUSAHAAN kita yang dibuat pada contoh di atas -

#include <iostream>
#include <pqxx/pqxx> 

using namespace std;
using namespace pqxx;

int main(int argc, char* argv[]) {
   char * sql;
   
   try {
      connection C("dbname = testdb user = postgres password = cohondob \
      hostaddr = 127.0.0.1 port = 5432");
      if (C.is_open()) {
         cout << "Opened database successfully: " << C.dbname() << endl;
      } else {
         cout << "Can't open database" << endl;
         return 1;
      }

      /* Create SQL statement */
      sql = "INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) "  \
         "VALUES (1, 'Paul', 32, 'California', 20000.00 ); " \
         "INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) "  \
         "VALUES (2, 'Allen', 25, 'Texas', 15000.00 ); "     \
         "INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)" \
         "VALUES (3, 'Teddy', 23, 'Norway', 20000.00 );" \
         "INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)" \
         "VALUES (4, 'Mark', 25, 'Rich-Mond ', 65000.00 );";

      /* Create a transactional object. */
      work W(C);
      
      /* Execute SQL query */
      W.exec( sql );
      W.commit();
      cout << "Records created successfully" << endl;
      C.disconnect ();
   } catch (const std::exception &e) {
      cerr << e.what() << std::endl;
      return 1;
   }

   return 0;
}

Ketika program yang diberikan di atas dikompilasi dan dijalankan, itu akan membuat catatan yang diberikan dalam tabel PERUSAHAAN dan akan menampilkan dua baris berikut -

Opened database successfully: testdb
Records created successfully

PILIH Operasi

Segmen kode C berikut menunjukkan bagaimana kita dapat mengambil dan menampilkan catatan dari tabel PERUSAHAAN kita yang dibuat pada contoh di atas -

#include <iostream>
#include <pqxx/pqxx> 

using namespace std;
using namespace pqxx;

int main(int argc, char* argv[]) {
   char * sql;
   
   try {
      connection C("dbname = testdb user = postgres password = cohondob \
      hostaddr = 127.0.0.1 port = 5432");
      if (C.is_open()) {
         cout << "Opened database successfully: " << C.dbname() << endl;
      } else {
         cout << "Can't open database" << endl;
         return 1;
      }

      /* Create SQL statement */
      sql = "SELECT * from COMPANY";

      /* Create a non-transactional object. */
      nontransaction N(C);
      
      /* Execute SQL query */
      result R( N.exec( sql ));
      
      /* List down all the records */
      for (result::const_iterator c = R.begin(); c != R.end(); ++c) {
         cout << "ID = " << c[0].as<int>() << endl;
         cout << "Name = " << c[1].as<string>() << endl;
         cout << "Age = " << c[2].as<int>() << endl;
         cout << "Address = " << c[3].as<string>() << endl;
         cout << "Salary = " << c[4].as<float>() << endl;
      }
      cout << "Operation done successfully" << endl;
      C.disconnect ();
   } catch (const std::exception &e) {
      cerr << e.what() << std::endl;
      return 1;
   }

   return 0;
}

Ketika program yang diberikan di atas dikompilasi dan dijalankan, itu akan menghasilkan hasil sebagai berikut -

Opened database successfully: testdb
ID = 1
Name = Paul
Age = 32
Address = California
Salary = 20000
ID = 2
Name = Allen
Age = 25
Address = Texas
Salary = 15000
ID = 3
Name = Teddy
Age = 23
Address = Norway
Salary = 20000
ID = 4
Name = Mark
Age = 25
Address = Rich-Mond
Salary = 65000
Operation done successfully

UPDATE Operasi

Segmen kode C berikut menunjukkan bagaimana kita dapat menggunakan pernyataan UPDATE untuk memperbarui catatan apa pun dan kemudian mengambil dan menampilkan catatan yang diperbarui dari tabel PERUSAHAAN kami -

#include <iostream>
#include <pqxx/pqxx> 

using namespace std;
using namespace pqxx;

int main(int argc, char* argv[]) {
   char * sql;
   
   try {
      connection C("dbname = testdb user = postgres password = cohondob \
      hostaddr = 127.0.0.1 port = 5432");
      if (C.is_open()) {
         cout << "Opened database successfully: " << C.dbname() << endl;
      } else {
         cout << "Can't open database" << endl;
         return 1;
      }
      
      /* Create a transactional object. */
      work W(C);
      /* Create  SQL UPDATE statement */
      sql = "UPDATE COMPANY set SALARY = 25000.00 where ID=1";
      /* Execute SQL query */
      W.exec( sql );
      W.commit();
      cout << "Records updated successfully" << endl;
      
      /* Create SQL SELECT statement */
      sql = "SELECT * from COMPANY";

      /* Create a non-transactional object. */
      nontransaction N(C);
      
      /* Execute SQL query */
      result R( N.exec( sql ));
      
      /* List down all the records */
      for (result::const_iterator c = R.begin(); c != R.end(); ++c) {
         cout << "ID = " << c[0].as<int>() << endl;
         cout << "Name = " << c[1].as<string>() << endl;
         cout << "Age = " << c[2].as<int>() << endl;
         cout << "Address = " << c[3].as<string>() << endl;
         cout << "Salary = " << c[4].as<float>() << endl;
      }
      cout << "Operation done successfully" << endl;
      C.disconnect ();
   } catch (const std::exception &e) {
      cerr << e.what() << std::endl;
      return 1;
   }

   return 0;
}

Ketika program yang diberikan di atas dikompilasi dan dijalankan, itu akan menghasilkan hasil sebagai berikut -

Opened database successfully: testdb
Records updated successfully
ID = 2
Name = Allen
Age = 25
Address = Texas
Salary = 15000
ID = 3
Name = Teddy
Age = 23
Address = Norway
Salary = 20000
ID = 4
Name = Mark
Age = 25
Address = Rich-Mond
Salary = 65000
ID = 1
Name = Paul
Age = 32
Address = California
Salary = 25000
Operation done successfully

HAPUS Operasi

Segmen kode C berikut menunjukkan bagaimana kita dapat menggunakan pernyataan DELETE untuk menghapus catatan apa pun dan kemudian mengambil dan menampilkan catatan yang tersisa dari tabel PERUSAHAAN kita -

#include <iostream>
#include <pqxx/pqxx> 

using namespace std;
using namespace pqxx;

int main(int argc, char* argv[]) {
   char * sql;
   
   try {
      connection C("dbname = testdb user = postgres password = cohondob \
      hostaddr = 127.0.0.1 port = 5432");
      if (C.is_open()) {
         cout << "Opened database successfully: " << C.dbname() << endl;
      } else {
         cout << "Can't open database" << endl;
         return 1;
      }
      
      /* Create a transactional object. */
      work W(C);
      /* Create  SQL DELETE statement */
      sql = "DELETE from COMPANY where ID = 2";
      /* Execute SQL query */
      W.exec( sql );
      W.commit();
      cout << "Records deleted successfully" << endl;
      
      /* Create SQL SELECT statement */
      sql = "SELECT * from COMPANY";

      /* Create a non-transactional object. */
      nontransaction N(C);
      
      /* Execute SQL query */
      result R( N.exec( sql ));
      
      /* List down all the records */
      for (result::const_iterator c = R.begin(); c != R.end(); ++c) {
         cout << "ID = " << c[0].as<int>() << endl;
         cout << "Name = " << c[1].as<string>() << endl;
         cout << "Age = " << c[2].as<int>() << endl;
         cout << "Address = " << c[3].as<string>() << endl;
         cout << "Salary = " << c[4].as<float>() << endl;
      }
      cout << "Operation done successfully" << endl;
      C.disconnect ();
   } catch (const std::exception &e) {
      cerr << e.what() << std::endl;
      return 1;
   }

   return 0;
}

Ketika program yang diberikan di atas dikompilasi dan dijalankan, itu akan menghasilkan hasil sebagai berikut -

Opened database successfully: testdb
Records deleted successfully
ID = 3
Name = Teddy
Age = 23
Address = Norway
Salary = 20000
ID = 4
Name = Mark
Age = 25
Address = Rich-Mond
Salary = 65000
ID = 1
Name = Paul
Age = 32
Address = California
Salary = 25000
Operation done successfully