文档章节

用C语言操作Sqlite数据库

学习环境
 学习环境
发布于 2015/10/14 19:13
字数 698
阅读 244
收藏 7

在工作中,我总是使用编译后sqlite3可执行程序,进行数据库的创建;其实我们操作sqlite数据库,

也可是使用源代码级别的形式去操作数据库。我在网上查找,对部分代码进行修改,添加上注释,

形式如下代码,其中包含对数据表的创建,添加数据,查询数据功能,代码如下:

#include <stdio.h>

#include <sqlite3.h>


//查询的回调函数声明

int select_callback(void * data, int col_count, char ** col_values, char ** col_Name);


int main(int argc, char * argv[])

{

  const char * sSQL1 = "create table users(userid varchar(20) PRIMARY KEY, age int, birthday datetime);";

  char * pErrMsg = 0;

  int result = 0;

  // 连接数据库

  sqlite3 * db = 0;

  int ret = sqlite3_open("./test.db", &db);

  if( ret != SQLITE_OK ) {

    fprintf(stderr, "无法打开数据库: %s", sqlite3_errmsg(db));

    return(1);

  }

  printf("数据库连接成功!\n");


  // 执行建表SQL

  sqlite3_exec( db, sSQL1, 0, 0, &pErrMsg );

  if( ret != SQLITE_OK ){

    fprintf(stderr, "SQL error: %s\n", pErrMsg);

    sqlite3_free(pErrMsg);

  }


  // 执行插入记录SQL

  result = sqlite3_exec( db, "insert into users values('张三',20,'2011-7-23');", 0, 0, &pErrMsg);

  if(result == SQLITE_OK){

    printf("插入数据成功\n");

  }

  result = sqlite3_exec( db, "insert into users values('李四',20,'2012-9-20');", 0, 0, &pErrMsg);

  if(result == SQLITE_OK){

    printf("插入数据成功\n");

  }


  // 查询数据表

  printf("查询数据库内容\n");

  sqlite3_exec( db, "select * from users;", select_callback, 0, &pErrMsg);


  // 关闭数据库

  sqlite3_close(db);

  db = 0;

  printf("数据库关闭成功!\n");


  return 0;

}


int select_callback(void * data, int col_count, char ** col_values, char ** col_Name)

{

  // 每条记录回调一次该函数,有多少条就回调多少次

  int i;

  for( i=0; i < col_count; i++){

    printf( "%s = %s\n", col_Name[i], col_values[i] == 0 ? "NULL" : col_values[i] );

  }


  return 0;

}

编写好代码后,我们需要进行编译。

我使用的ubuntu10.04自带的gcc编译器gcc4.4.3进行编译。

如果你使用 $ gcc sqlitetest.c

进行编译时,会出现如下的错误:

/tmp/ccyxvdme.o: In function `main':

sqlitetest.c:(.text+0x31): undefined reference to `sqlite3_open'

sqlitetest.c:(.text+0x48): undefined reference to `sqlite3_errmsg'

sqlitetest.c:(.text+0xa5): undefined reference to `sqlite3_exec'

sqlitetest.c:(.text+0xd6): undefined reference to `sqlite3_free'

sqlitetest.c:(.text+0x102): undefined reference to `sqlite3_exec'

sqlitetest.c:(.text+0x12e): undefined reference to `sqlite3_exec'

sqlitetest.c:(.text+0x15a): undefined reference to `sqlite3_exec'

sqlitetest.c:(.text+0x166): undefined reference to `sqlite3_close'

collect2: ld returned 1 exit status

这是因为gcc找不到定义sqlite3_open等等的头文件,经过在网上查找资料,

找到了解决方法,使用如下的方法进行编译:

$ gcc -o hello -L /usr/local/sqlite-autoconf-3070400/lib -I/usr/local/sqlite-autoconf-307040/include sqlitetest.c  -lsqlite3

上面的编译主要意义时-L 代码你安装sqlite3类库所在的路径, -I代表安装sqlite3的头文件路径 而-l表示

可执行程序的名称

经过上面的编译,即可成功。

执行结果如下:

~$ ./hello

数据库连接成功!

插入数据成功

插入数据成功

查询数据库内容

userid = 张三

age = 20

birthday = 2011-7-23

userid = 李四

age = 20

birthday = 2012-9-20

数据库关闭成功!


© 著作权归作者所有

共有 人打赏支持
学习环境
粉丝 3
博文 51
码字总数 115814
作品 0
长春
私信 提问
轻巧的本地数据库 - sqlite

  前言   SQLite,是一款轻型的数据库,它的设计目标是嵌入式的,而且现在很多嵌入式产品中使用它,它占资源非常低,在嵌入设备中,可能只需要几百K的内存就够了。它能够支持Windows/Lin...

linux运维菜
11/01
0
0
sqlite3 用SQLCipher 加密后 命令行下如何重新打开和读取

http://sqlcipher.net/sqlcipher-api/#key PRAGMA key The process of creating a new, encrypted database is called “keying” the database. SQLCipher uses just-in-time key derivati......

kjpioo
2013/08/01
0
2
发布至今18年,为什么SQLite一定要用C语言来开发?

SQLite 选择 C 语言的理由是?为什么不选择 Go 或者 Rust? C 语言是最好的 SQLite 在 2000 年 5 月 29 日发布,并一直使用 C 语言实现。C 语言一直是实现 SQLite 这类软件库的最佳语言,目前...

程序师
08/23
0
0
Android 小项目之--SQLite 使用法门

每个应用程序都要使用数据,Android应用程序也不例外,Android使用开源的、与操作系统无关的SQL数据库 --大名鼎鼎的SQLite。SQLite是一款轻量级数据库,它的设计目的是嵌入式,而且它占用的资...

mayi
2011/11/14
0
2
不会点SQLite,都不好意思说自己是开发的

一、为什么要会点SQLite? SQLite作为一款轻量级的关系型数据库,占用的资源特别少,所以其应用场景也是特别的多。在移动开发中,我们经常会有将数据存储在本地的需求,此时SQLite将是我们最...

silencezwm
07/03
0
0

没有更多内容

加载失败,请刷新页面

加载更多

node安装cnpm

npm install -g cnpm --registry=https://registry.npm.taobao.org

笑丶笑
7分钟前
0
0
OSChina 周三乱弹 —— 夜半回家,推门不动

Osc乱弹歌单(2018)请戳(这里) 【今日歌曲】 @胖达panda :分享陶晶莹/张雨生的单曲《我期待》 《我期待》- 陶晶莹/张雨生 手机党少年们想听歌,请使劲儿戳(这里) @cc_z :熬夜一时爽,...

小小编辑
19分钟前
27
3
验证码

response生成验证码 验证码的作用:防止恶意注册、攻击等 网站上看到的验证码,实际上都是一些图片,而这些图片都是程序(Servlet)生成的! package day19.test; import java.awt.Color; i...

码农屌丝
57分钟前
1
0
day147-2018-11-14-英语流利阅读-待学习

《毒液》刚刚上映,创造漫威宇宙的人却走了 雪梨 2018-11-14 1.今日导读 中国的金庸创造了侠义英雄和江湖传奇,而大洋彼岸的斯坦·李也同样创造了一个绚烂璀璨的漫威宇宙,他构思的每个超级英...

飞鱼说编程
58分钟前
6
0
CentOS 安装PHP5和PHP7

安装PHP5 下载解压二进制包 [root@test-a src]# cd /usr/local/src/[root@test-a src]# wget http://cn2.php.net/distributions/php-5.6.32.tar.bz2[root@test-a src]# tar jxvf php-5.6......

野雪球
今天
4
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部