PostgreSQL - C / C ++ इंटरफ़ेस
यह ट्यूटोरियल उपयोग करने वाला है libpqxxलाइब्रेरी, जो कि पोस्टग्रेक्यूएल के लिए आधिकारिक सी ++ क्लाइंट एपीआई है। Libpqxx का स्रोत कोड BSD लाइसेंस के तहत उपलब्ध है, इसलिए आप इसे डाउनलोड करने, दूसरों को इसे पास करने, इसे बदलने, इसे बेचने, इसे अपने कोड में शामिल करने और आपके द्वारा चुने गए किसी के साथ अपने परिवर्तन साझा करने के लिए स्वतंत्र हैं।
इंस्टालेशन
Libpqxx का नवीनतम संस्करण लिंक डाउनलोड Libpqxx से डाउनलोड करने के लिए उपलब्ध है । तो नवीनतम संस्करण डाउनलोड करें और निम्नलिखित चरणों का पालन करें -
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
इससे पहले कि आप C / C ++ PostgreSQL इंटरफ़ेस का उपयोग शुरू करें, खोजें pg_hba.conf अपने PostgreSQL इंस्टॉलेशन डायरेक्टरी में फाइल करें और निम्न लाइन जोड़ें -
# IPv4 local connections:
host all all 127.0.0.1/32 md5
यदि आप निम्नलिखित कमांड का उपयोग करके नहीं चल रहे हैं, तो आप सर्वर को शुरू / फिर से शुरू कर सकते हैं -
[root@host]# service postgresql restart
Stopping postgresql service: [ OK ]
Starting postgresql service: [ OK ]
C / C ++ इंटरफ़ेस APIs
निम्नलिखित महत्वपूर्ण इंटरफ़ेस रूटीन हैं जो आपके C / C ++ प्रोग्राम से PostgreSQL डेटाबेस के साथ काम करने के लिए आपकी आवश्यकता को पूरा कर सकते हैं। यदि आप एक अधिक परिष्कृत आवेदन की तलाश कर रहे हैं तो आप libpqxx आधिकारिक दस्तावेज में देख सकते हैं, या आप व्यावसायिक रूप से उपलब्ध एपीआई का उपयोग कर सकते हैं।
एस। | एपीआई और विवरण |
---|---|
1 | pqxx::connection C( const std::string & dbstring ) यह एक टंकण है जो डेटाबेस से जुड़ने के लिए उपयोग किया जाएगा। यहां, उदाहरण के लिए, dbstring डेटाबेस से कनेक्ट करने के लिए आवश्यक पैरामीटर प्रदान करता हैdbname = testdb user = postgres password=pass123 hostaddr=127.0.0.1 port=5432। यदि कनेक्शन सफलतापूर्वक सेटअप है तो यह कनेक्शन ऑब्जेक्ट के साथ सी बनाता है जो विभिन्न उपयोगी फ़ंक्शन सार्वजनिक फ़ंक्शन प्रदान करता है। |
2 | C.is_open() विधि is_open () कनेक्शन ऑब्जेक्ट का एक सार्वजनिक तरीका है और बूलियन मान लौटाता है। यदि कनेक्शन सक्रिय है, तो यह तरीका सही है अन्यथा यह गलत है। |
3 | C.disconnect() इस पद्धति का उपयोग किसी खोले हुए डेटाबेस कनेक्शन को डिस्कनेक्ट करने के लिए किया जाता है। |
4 | pqxx::work W( C ) यह एक टाइपसेफ है जिसका उपयोग कनेक्शन सी का उपयोग करके एक ट्रांजेक्शनल ऑब्जेक्ट बनाने के लिए किया जाएगा, जो अंततः एसक्यूएल स्टेटमेंट को ट्रांजेक्शनल मोड में निष्पादित करने के लिए उपयोग किया जाएगा। यदि लेन-देन ऑब्जेक्ट सफलतापूर्वक बनाया जाता है, तो इसे चर डब्ल्यू को सौंपा जाता है जिसका उपयोग ट्रांजेक्शनल ऑब्जेक्ट से संबंधित सार्वजनिक तरीकों तक पहुंचने के लिए किया जाएगा। |
5 | W.exec(const std::string & sql) Transactional ऑब्जेक्ट से इस सार्वजनिक विधि का उपयोग SQL स्टेटमेंट को निष्पादित करने के लिए किया जाएगा। |
6 | W.commit() लेन-देन करने के लिए ट्रांजेक्शनल ऑब्जेक्ट से इस सार्वजनिक विधि का उपयोग किया जाएगा। |
7 | W.abort() लेन-देन को रोलबैक करने के लिए ट्रांजेक्शनल ऑब्जेक्ट से इस सार्वजनिक विधि का उपयोग किया जाएगा। |
8 | pqxx::nontransaction N( C ) यह एक टाइपसेफ है जिसका उपयोग कनेक्शन सी का उपयोग करके एक गैर-ट्रांजेक्शनल ऑब्जेक्ट बनाने के लिए किया जाएगा, जिसका उपयोग अंततः गैर-लेन-देन मोड में SQL स्टेटमेंट्स को निष्पादित करने के लिए किया जाएगा। यदि लेन-देन ऑब्जेक्ट सफलतापूर्वक बनाया जाता है, तो इसे चर एन को सौंपा जाता है, जिसका उपयोग गैर-लेन-देन ऑब्जेक्ट से संबंधित सार्वजनिक तरीकों तक पहुंचने के लिए किया जाएगा। |
9 | N.exec(const std::string & sql) गैर-लेन-देन ऑब्जेक्ट से इस सार्वजनिक विधि का उपयोग SQL स्टेटमेंट को निष्पादित करने के लिए किया जाएगा और एक परिणाम ऑब्जेक्ट लौटाएगा जो वास्तव में सभी लौटे रिकॉर्डों को पकड़े हुए एक इंटरएटर है। |
Connecting To Database
The following C code segment shows how to connect to an existing database running on local machine at port 5432. Here, I used backslash \ for line continuation.
#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;
}
}
Now, let us compile and run the above program to connect to our database testdb, which is already available in your schema and can be accessed using user postgres and password pass123.
You can use the user ID and password based on your database setting. Remember to keep the -lpqxx and -lpq in the given order! Otherwise, the linker will complain bitterly about the missing functions with names starting with "PQ."
$g++ test.cpp -lpqxx -lpq
$./a.out
Opened database successfully: testdb
Create a Table
The following C code segment will be used to create a table in previously created database −
#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;
}
When the above given program is compiled and executed, it will create COMPANY table in your testdb database and will display the following statements −
Opened database successfully: testdb
Table created successfully
INSERT Operation
The following C code segment shows how we can create records in our COMPANY table created in above example −
#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;
}
When the above given program is compiled and executed, it will create given records in COMPANY table and will display the following two lines −
Opened database successfully: testdb
Records created successfully
SELECT Operation
The following C code segment shows how we can fetch and display records from our COMPANY table created in above example −
#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;
}
When the above given program is compiled and executed, it will produce the following result −
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 Operation
The following C code segment shows how we can use the UPDATE statement to update any record and then fetch and display updated records from our COMPANY table −
#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;
}
When the above given program is compiled and executed, it will produce the following result −
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
DELETE Operation
The following C code segment shows how we can use the DELETE statement to delete any record and then fetch and display remaining records from our COMPANY table −
#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;
}
When the above given program is compiled and executed, it will produce the following result −
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