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