SQLite - C / C ++
इस अध्याय में, आप सीखेंगे कि C / C ++ प्रोग्राम में SQLite का उपयोग कैसे करें।
इंस्टालेशन
इससे पहले कि आप हमारे C / C ++ प्रोग्राम में SQLite का उपयोग करना शुरू करें, आपको यह सुनिश्चित करने की आवश्यकता है कि आपके पास मशीन पर SQLite लाइब्रेरी स्थापित है। स्थापना प्रक्रिया को समझने के लिए आप SQLite अधिष्ठापन अध्याय की जांच कर सकते हैं।
C / C ++ इंटरफ़ेस APIs
निम्नलिखित महत्वपूर्ण C / C ++ SQLite इंटरफ़ेस रूटीन हैं, जो आपके C / C ++ प्रोग्राम से SQLite डेटाबेस के साथ काम करने की आपकी आवश्यकता को पूरा कर सकते हैं। यदि आप एक अधिक परिष्कृत आवेदन की तलाश कर रहे हैं, तो आप SQLite आधिकारिक दस्तावेज में देख सकते हैं।
अनु क्रमांक। | एपीआई और विवरण |
---|---|
1 | sqlite3_open(const char *filename, sqlite3 **ppDb) यह रूटीन एक SQLite डेटाबेस फ़ाइल के लिए एक कनेक्शन खोलता है और अन्य SQLite दिनचर्या द्वारा उपयोग किए जाने वाले डेटाबेस कनेक्शन ऑब्जेक्ट देता है। यदि फ़ाइल नाम तर्क NULL या ': मेमोरी:' है, तो sqlite3_open () RAM में एक इन-मेमोरी डेटाबेस बनाएगा जो केवल सत्र की अवधि तक रहता है। यदि फ़ाइल नाम NULL नहीं है, तो sqlite3_open () डेटाबेस फ़ाइल को उसके मान का उपयोग करके खोलने का प्रयास करता है। यदि उस नाम की कोई फ़ाइल मौजूद नहीं है, तो sqlite3_open () उस नाम से एक नई डेटाबेस फ़ाइल खोलेगी। |
2 | sqlite3_exec(sqlite3*, const char *sql, sqlite_callback, void *data, char **errmsg) यह दिनचर्या एसक्यूएल तर्क द्वारा प्रदान की गई एसक्यूएल कमांड को निष्पादित करने का एक त्वरित, आसान तरीका प्रदान करती है जिसमें एक से अधिक एसक्यूएल कमांड शामिल हो सकते हैं। यहां, पहला तर्क sqlite3 एक ओपन डेटाबेस ऑब्जेक्ट है, sqlite_callback एक कॉल बैक है जिसके लिए डेटा 1 तर्क है और दिनचर्या द्वारा उठाए गए किसी भी त्रुटि को कैप्चर करने के लिए इरम्सग को वापस कर दिया जाएगा। SQLite3_exec () रूटीन पर्स और दिए गए हर कमांड को निष्पादित करता है sql तर्क जब तक यह स्ट्रिंग के अंत तक नहीं पहुंचता या एक त्रुटि का सामना करता है। |
3 | sqlite3_close(sqlite3*) यह दिनचर्या sqlite3_open () को कॉल द्वारा खोले गए डेटाबेस कनेक्शन को बंद कर देती है। कनेक्शन को बंद करने से पहले कनेक्शन से जुड़े सभी तैयार बयानों को अंतिम रूप दिया जाना चाहिए। यदि कोई भी प्रश्न अंतिम रूप से नहीं है, तो sqlite3_close () त्रुटि संदेश के साथ SQLITE_BUSY वापस कर देगा। |
डेटाबेस से कनेक्ट करें
निम्नलिखित सी कोड खंड दिखाता है कि मौजूदा डेटाबेस से कैसे कनेक्ट किया जाए। यदि डेटाबेस मौजूद नहीं है, तो इसे बनाया जाएगा और अंत में एक डेटाबेस ऑब्जेक्ट वापस कर दिया जाएगा।
#include <stdio.h>
#include <sqlite3.h>
int main(int argc, char* argv[]) {
sqlite3 *db;
char *zErrMsg = 0;
int rc;
rc = sqlite3_open("test.db", &db);
if( rc ) {
fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
return(0);
} else {
fprintf(stderr, "Opened database successfully\n");
}
sqlite3_close(db);
}
अब, हमारे डेटाबेस बनाने के लिए उपरोक्त प्रोग्राम को संकलित करें और चलाएं test.dbवर्तमान निर्देशिका में। आप अपनी आवश्यकता के अनुसार अपना रास्ता बदल सकते हैं।
$gcc test.c -l sqlite3
$./a.out
Opened database successfully
यदि आप C ++ स्रोत कोड का उपयोग करने जा रहे हैं, तो आप अपना कोड निम्नानुसार संकलित कर सकते हैं -
$g++ test.c -l sqlite3
यहाँ, हम C प्रोग्राम को आवश्यक कार्य प्रदान करने के लिए अपने प्रोग्राम को sqlite3 लाइब्रेरी से जोड़ रहे हैं। यह आपकी निर्देशिका में एक डेटाबेस फ़ाइल test.db बनाएगा और आपके पास निम्न परिणाम होगा।
-rwxr-xr-x. 1 root root 7383 May 8 02:06 a.out
-rw-r--r--. 1 root root 323 May 8 02:05 test.c
-rw-r--r--. 1 root root 0 May 8 02:06 test.db
एक तालिका बनाएँ
निम्नलिखित कोड डेटाबेस में तालिका बनाने के लिए निम्नलिखित सी कोड सेगमेंट का उपयोग किया जाएगा -
#include <stdio.h>
#include <stdlib.h>
#include <sqlite3.h>
static int callback(void *NotUsed, int argc, char **argv, char **azColName) {
int i;
for(i = 0; i<argc; i++) {
printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");
}
printf("\n");
return 0;
}
int main(int argc, char* argv[]) {
sqlite3 *db;
char *zErrMsg = 0;
int rc;
char *sql;
/* Open database */
rc = sqlite3_open("test.db", &db);
if( rc ) {
fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
return(0);
} else {
fprintf(stdout, "Opened database successfully\n");
}
/* 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 );";
/* Execute SQL statement */
rc = sqlite3_exec(db, sql, callback, 0, &zErrMsg);
if( rc != SQLITE_OK ){
fprintf(stderr, "SQL error: %s\n", zErrMsg);
sqlite3_free(zErrMsg);
} else {
fprintf(stdout, "Table created successfully\n");
}
sqlite3_close(db);
return 0;
}
जब उपरोक्त कार्यक्रम संकलित और निष्पादित किया जाता है, तो यह आपके test.db में कंपनी तालिका बनाएगा और फ़ाइल की अंतिम सूची इस प्रकार होगी -
-rwxr-xr-x. 1 root root 9567 May 8 02:31 a.out
-rw-r--r--. 1 root root 1207 May 8 02:31 test.c
-rw-r--r--. 1 root root 3072 May 8 02:31 test.db
INSERT ऑपरेशन
निम्नलिखित सी कोड खंड दिखाता है कि आप उपरोक्त उदाहरण में बनाई गई कंपनी तालिका में रिकॉर्ड कैसे बना सकते हैं -
#include <stdio.h>
#include <stdlib.h>
#include <sqlite3.h>
static int callback(void *NotUsed, int argc, char **argv, char **azColName) {
int i;
for(i = 0; i<argc; i++) {
printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");
}
printf("\n");
return 0;
}
int main(int argc, char* argv[]) {
sqlite3 *db;
char *zErrMsg = 0;
int rc;
char *sql;
/* Open database */
rc = sqlite3_open("test.db", &db);
if( rc ) {
fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
return(0);
} else {
fprintf(stderr, "Opened database successfully\n");
}
/* 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 );";
/* Execute SQL statement */
rc = sqlite3_exec(db, sql, callback, 0, &zErrMsg);
if( rc != SQLITE_OK ){
fprintf(stderr, "SQL error: %s\n", zErrMsg);
sqlite3_free(zErrMsg);
} else {
fprintf(stdout, "Records created successfully\n");
}
sqlite3_close(db);
return 0;
}
जब उपरोक्त कार्यक्रम संकलित और निष्पादित किया जाता है, तो यह कंपनी तालिका में दिए गए रिकॉर्ड बनाएगा और निम्नलिखित दो लाइनें प्रदर्शित करेगा -
Opened database successfully
Records created successfully
ऑपरेशन का चयन करें
रिकॉर्ड प्राप्त करने के लिए वास्तविक उदाहरण के साथ आगे बढ़ने से पहले, आइए कॉलबैक फ़ंक्शन के बारे में कुछ विस्तार से देखें, जिसका उपयोग हम अपने उदाहरणों में कर रहे हैं। यह कॉलबैक SELECT स्टेटमेंट्स से परिणाम प्राप्त करने का एक तरीका प्रदान करता है। इसकी निम्नलिखित घोषणा है -
typedef int (*sqlite3_callback)(
void*, /* Data provided in the 4th argument of sqlite3_exec() */
int, /* The number of columns in row */
char**, /* An array of strings representing fields in the row */
char** /* An array of strings representing column names */
);
यदि तीसरा तर्क के रूप में उपर्युक्त कॉलबैक sqlite_exec () दिनचर्या में प्रदान किया गया है, तो SQLite, SQL तर्क में निष्पादित प्रत्येक सेलेक्ट स्टेटमेंट में संसाधित प्रत्येक रिकॉर्ड के लिए इस कॉलबैक फ़ंक्शन को कॉल करेगा।
निम्नलिखित सी कोड खंड दिखाता है कि आप उपरोक्त उदाहरण में बनाई गई कंपनी तालिका से रिकॉर्ड कैसे प्राप्त और प्रदर्शित कर सकते हैं -
#include <stdio.h>
#include <stdlib.h>
#include <sqlite3.h>
static int callback(void *data, int argc, char **argv, char **azColName){
int i;
fprintf(stderr, "%s: ", (const char*)data);
for(i = 0; i<argc; i++){
printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");
}
printf("\n");
return 0;
}
int main(int argc, char* argv[]) {
sqlite3 *db;
char *zErrMsg = 0;
int rc;
char *sql;
const char* data = "Callback function called";
/* Open database */
rc = sqlite3_open("test.db", &db);
if( rc ) {
fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
return(0);
} else {
fprintf(stderr, "Opened database successfully\n");
}
/* Create SQL statement */
sql = "SELECT * from COMPANY";
/* Execute SQL statement */
rc = sqlite3_exec(db, sql, callback, (void*)data, &zErrMsg);
if( rc != SQLITE_OK ) {
fprintf(stderr, "SQL error: %s\n", zErrMsg);
sqlite3_free(zErrMsg);
} else {
fprintf(stdout, "Operation done successfully\n");
}
sqlite3_close(db);
return 0;
}
जब उपरोक्त कार्यक्रम संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम देगा।
Opened database successfully
Callback function called: ID = 1
NAME = Paul
AGE = 32
ADDRESS = California
SALARY = 20000.0
Callback function called: ID = 2
NAME = Allen
AGE = 25
ADDRESS = Texas
SALARY = 15000.0
Callback function called: ID = 3
NAME = Teddy
AGE = 23
ADDRESS = Norway
SALARY = 20000.0
Callback function called: ID = 4
NAME = Mark
AGE = 25
ADDRESS = Rich-Mond
SALARY = 65000.0
Operation done successfully
अद्यतन ऑपरेशन
C कोड सेगमेंट का अनुसरण यह दर्शाता है कि हम किसी भी रिकॉर्ड को अपडेट करने के लिए UPDATE स्टेटमेंट का उपयोग कैसे कर सकते हैं और फिर कंपनी टेबल से अपडेट किए गए रिकॉर्ड प्राप्त और प्रदर्शित कर सकते हैं।
#include <stdio.h>
#include <stdlib.h>
#include <sqlite3.h>
static int callback(void *data, int argc, char **argv, char **azColName){
int i;
fprintf(stderr, "%s: ", (const char*)data);
for(i = 0; i<argc; i++) {
printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");
}
printf("\n");
return 0;
}
int main(int argc, char* argv[]) {
sqlite3 *db;
char *zErrMsg = 0;
int rc;
char *sql;
const char* data = "Callback function called";
/* Open database */
rc = sqlite3_open("test.db", &db);
if( rc ) {
fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
return(0);
} else {
fprintf(stderr, "Opened database successfully\n");
}
/* Create merged SQL statement */
sql = "UPDATE COMPANY set SALARY = 25000.00 where ID=1; " \
"SELECT * from COMPANY";
/* Execute SQL statement */
rc = sqlite3_exec(db, sql, callback, (void*)data, &zErrMsg);
if( rc != SQLITE_OK ) {
fprintf(stderr, "SQL error: %s\n", zErrMsg);
sqlite3_free(zErrMsg);
} else {
fprintf(stdout, "Operation done successfully\n");
}
sqlite3_close(db);
return 0;
}
जब उपरोक्त कार्यक्रम संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम देगा।
Opened database successfully
Callback function called: ID = 1
NAME = Paul
AGE = 32
ADDRESS = California
SALARY = 25000.0
Callback function called: ID = 2
NAME = Allen
AGE = 25
ADDRESS = Texas
SALARY = 15000.0
Callback function called: ID = 3
NAME = Teddy
AGE = 23
ADDRESS = Norway
SALARY = 20000.0
Callback function called: ID = 4
NAME = Mark
AGE = 25
ADDRESS = Rich-Mond
SALARY = 65000.0
Operation done successfully
DELETE ऑपरेशन
निम्नलिखित सी कोड सेगमेंट में दिखाया गया है कि आप किसी भी रिकॉर्ड को हटाने के लिए DELETE स्टेटमेंट का उपयोग कैसे कर सकते हैं और फिर कंपनी तालिका से शेष रिकॉर्ड प्राप्त कर सकते हैं।
#include <stdio.h>
#include <stdlib.h>
#include <sqlite3.h>
static int callback(void *data, int argc, char **argv, char **azColName) {
int i;
fprintf(stderr, "%s: ", (const char*)data);
for(i = 0; i<argc; i++) {
printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");
}
printf("\n");
return 0;
}
int main(int argc, char* argv[]) {
sqlite3 *db;
char *zErrMsg = 0;
int rc;
char *sql;
const char* data = "Callback function called";
/* Open database */
rc = sqlite3_open("test.db", &db);
if( rc ) {
fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
return(0);
} else {
fprintf(stderr, "Opened database successfully\n");
}
/* Create merged SQL statement */
sql = "DELETE from COMPANY where ID=2; " \
"SELECT * from COMPANY";
/* Execute SQL statement */
rc = sqlite3_exec(db, sql, callback, (void*)data, &zErrMsg);
if( rc != SQLITE_OK ) {
fprintf(stderr, "SQL error: %s\n", zErrMsg);
sqlite3_free(zErrMsg);
} else {
fprintf(stdout, "Operation done successfully\n");
}
sqlite3_close(db);
return 0;
}
जब उपरोक्त कार्यक्रम संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम देगा।
Opened database successfully
Callback function called: ID = 1
NAME = Paul
AGE = 32
ADDRESS = California
SALARY = 20000.0
Callback function called: ID = 3
NAME = Teddy
AGE = 23
ADDRESS = Norway
SALARY = 20000.0
Callback function called: ID = 4
NAME = Mark
AGE = 25
ADDRESS = Rich-Mond
SALARY = 65000.0
Operation done successfully