运维入门——SQLite接口——C/C++

SQLite接口——C/C++

安装

在C/C++程序中使用SQLite之前,需要确保机器上已经又SQLite库。可以查看SQLite安装章节了解安装过程。

C/C++接口API

以下是重要的C&C++/SQLite接口程序,可以满足在C/C++程序中使用SQLite数据库的需求。如果需要了解更多细节,请查看SQLite官方文档。

序号API & 描述

1.sqlite3_open(const char *filename, sqlite3 **ppDb)

该例程打开一个指向 SQLite 数据库文件的连接,返回一个用于其他 SQLite 程序的数据库连接对象。

如果filename参数是 NULL 或 ':memory:',那么 sqlite3_open() 将会在 RAM 中创建一个内存数据库,这只会在 session 的有效时间内持续。

如果文件名 filename 不为 NULL,那么 sqlite3_open() 将使用这个参数值尝试打开数据库文件。如果该名称的文件不存在,sqlite3_open() 将创建一个新的命名为该名称的数据库文件并打开。

2.sqlite3_exec(sqlite3*, const char *sql, sqlite_callback, void *data, char **errmsg)

该例程提供了一个执行 SQL 命令的快捷方式,SQL 命令由 sql 参数提供,可以由多个 SQL 命令组成。

在这里,第一个参数sqlite3是打开的数据库对象,sqlite_callback是一个回调,data作为其第一个参数,errmsg 将被返回用来获取程序生成的任何错误。

sqlite3_exec() 程序解析并执行由sql参数所给的每个命令,直到字符串结束或者遇到错误为止。

3.sqlite3_close(sqlite3*)

该例程关闭之前调用 sqlite3_open() 打开的数据库连接。所有与连接相关的语句都应在连接关闭之前完成。

如果还有查询没有完成,sqlite3_close() 将返回 SQLITE_BUSY 禁止关闭的错误消息。

连接数据库

下面的 C 代码段显示了如何连接到一个现有的数据库。如果数据库不存在,那么它就会被创建,最后将返回一个数据库对象。

#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));

      exit(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

在这里,把我们的程序链接上 sqlite3 库,以便向 C 程序提供必要的函数。这将在您的目录下创建一个数据库文件 test.db,您将得到如下结果:

-rwxr-xr-x. 1 root root 7383 May  8 02:06 a.out

-rw-r--r--. 1root root  323 May  8 02:05 test.c

-rw-r--r--. 1root root    0 May  8 02:06 test.db

创建表

下面的 C 代码段将用于在先前创建的数据库中创建一个表:

#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));

      exit(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 文件中创建 COMPANY 表,最终文件列表如下所示:

-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 操作

下面的 C 代码段显示了如何在上面创建的 COMPANY 表中创建记录:

#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));

      exit(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;

}

上述程序编译和执行时,它会在 COMPANY 表中创建给定记录,并会显示以下两行:

Opened database successfully

Records created successfully

SELECT 操作

在我们开始讲解获取记录的实例之前,让我们先了解下回调函数的一些细节,这将在我们的实例使用到。这个回调提供了一个从 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 参数内执行的每个 SELECT 语句中处理的每个记录调用这个回调函数。

下面的 C 代码段显示了如何从前面创建的 COMPANY 表中获取并显示记录:

#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));

      exit(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

UPDATE 操作

下面的 C 代码段显示了如何使用 UPDATE 语句来更新任何记录,然后从 COMPANY 表中获取并显示更新的记录:

#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));

      exit(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 操作

下面的 C 代码段显示了如何使用 DELETE 语句删除任何记录,然后从 COMPANY 表中获取并显示剩余的记录:

#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));

      exit(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



end

微信搜索:嘀嗒运维

有惊喜!

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,732评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,496评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,264评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,807评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,806评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,675评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,029评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,683评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,704评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,666评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,773评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,413评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,016评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,204评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,083评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,503评论 2 343

推荐阅读更多精彩内容