Linux C语言操作SQLite数据库

1. SQLite数据库特点

(1)SQLite数据库是开源的嵌入式数据库,无需独立的数据库引擎,直接嵌入到应用程序进程中,因此,通过API,应用程序可以直接操作它。

(2)事务的处理是原子的,一致的,独立的,可持久化的(ACID),即使在系统崩溃和掉电后。

(3)SQLite数据库通过独占性与共享锁来实现事务的独立处理。

(4)一个单独的跨平台的磁盘文件就能够存储一个数据库。

(5)能支持2TB级的数据。

(6)自包含,无外部依赖性。

(7)支持NULL,INTEGER,NUMERIC,REAL,TEXT和BLOG等数据类型。

(8)SQLite数据库没有用户帐户的概念。数据库的权限仅依赖于文件系统。

 

 

2. SQLite数据库的基本操作

(1)建立数据库

sqlite3 data.sqlite3

 在当前目录下建立了名为data.sqlite3的数据库。

 

(2)建立数据表

create table call_list (id INTEGER PRIMARY KEY, type NUMERIC,telnum NUMERIC,bttime TEXT,tcount NUMERIC,charge_rate NUMERIC,charge_sum NUMERIC);

建立了名为 call_list的数据表,有7个字段,分别为id,type,telnum,bttime,tcount,charge_sum.charge_rate.

 

(3)向数据表中插入数据

 insert into call_list values ($num,1,2,'new',4,5,6);

 

(4)查询数据表中的数据

select * from call_list;

 

(5)修改call_list表中的数据

 update call_list set id=00001000 where id=10001;

 

 (6)删除表中的数据记录

 delete from call_list where id=1000;

 

 (7)SQlite中的其它常用命令

.tables -列出所有的数据库中的数据表

.schema tablename -列出指定数据表的结构

.quit -离开数据库

 

(8)SQLite数据库的导入与导出

 a.将data.sqlite数据库的数据全部导出:

sqlite3 data.sqlite

 >.output dd.sql

 >.dump

这样,数据就保存在dd.sql的文件中,注意这个文件不是数据库,而是SQL语句。

然后再把这些数据导入到另外一个数据库data1.sqlite数据库中。

sqlite3 data1.sqlite

>.read dd.sql

这样,数据就从data.sqlite数据库复制到data1.sqlite数据库中去了。

 

b.将数据表中的数据导出到a.txt中去

.output a.txt //输出重定向到a.txt

select * from call_list;

 

c.将导出的表中的数据导入到另一个数据库的新建的表中去

如:当从data.sqlite中的call_list表中导出了数据,再导入到另外一个数据库表call中去。

首先建立表call.

然后.import a.txt call 即可。

 

 

 

3. C语言操作Sqlite数据库

API:

 int sqlite3_open(const char* filename,sqlite3**ppdb);

第一个参数用来指定数据库文件名。

第二个参数是一个数据库标识符指针。

如果打开数据库成功,则返回0,否则返回一个错误代码。

 

int sqlite3_close(sqlite3*);

传递的参数是数据库标识符指针用来关闭数据库,操作成功是返回0,否则返回一个错误代码。

 

 int sqlite3_errcode(sqlite3*db);

 const char* sqlite3_errmsg(sqlite3* db);

const char* sqlite3_errmsg16(sqlite3* db);

这三个函数都是返回错误信息,第一个函数返回的是最近调用数据库接口的错误代码,第二,第三个函数是返回最近调用数据库接口的错误信息。第二个函数返回的错误信息是用UTF-8编码的,第三个函数返回的错误信息是用UTF-16编码的。

 

 int sqlite3_exec(sqlite3*,const char*sql,int(*callback)(void*,int,char**,char**),void*,**errmsg);

这个函数非常重用,是用来执行SQLite数据库的SQL语句的。

第一个参数是sqlite数据库标识符指针。

第二个参数是要执行的SQL语句。

第三个参数是一个回调函数,在执行查询操作时用到,其它的操作可以传空值即NULL。

第四个参数是传递给回调函数第一个参数的实参。

第五个参数是一个错误信息。

 

 回调函数: int callback(void*,int argc,char** argv,char** cname);

第一个参数是从sqlite3_exec传递过来的参数,可以为任意的类型。

第二个参数是查询的列数。

第三个参数是查询结果集的值。

第四个参数是列名。

 

int sqlite3_get_table(sqlite3*db,const char* sql,char***result,int *row,int*col,char** errmsg);

 这个函数主要是用来查询的。

第一个参数是数据库描述符指针

第二个参数是SQL语句。

第三个参数是查询的结果集。

第四个参数是结果集中的行数。

第五个参数是结果集中的列数。

第六个参数是错误信息。

它查询出的行数是从字段名开始的。即第0行是字段名。

 

 实例:

/**
本例主要实现用Sqlite的回调函数进行查询
int sqlite3_exec(sqlite3*,const char* sql,int (*callback)(void*,int,char**,char**),void*,errmsg);
第一个参数是数据库标识符
第二个参数是要执行的sql命令
第三个参数是回调函数
第四个参数是回调函数的第一个参数
第五个参数是用于指示错误信息
其中回调函数的形式:
int _sql_callback(void*arg,int argc,char**argv,char**cname);
第二个参数指示结果集中的列数
第三个参数是保存结果集的字符串
第四个参数是结果集中的列名
**/
#include <string.h>
#include <stdlib.h>
#include <stdio.h>
#include <unistd.h>
#include <sqlite3.h>
#include <time.h>
int _call_back(void*arg,int argc,char** argv,char** cname);
int main(){
int res;
const char*dbfile="data.sqlite1";
char*errmsg=NULL;
sqlite3* db;
res=sqlite3_open(dbfile,&db);
if(res!=0){
  perror("数据库打开失败");
  exit(EXIT_FAILURE);
}
//创建一张数据表
const char* sqlcreate="create table call_list (id INTEGER PRIMARY KEY, type NUMERIC,telnum NUMERIC,bttime TEXT,tcount NUMERIC,charge_rate NUMERIC,charge_sum NUMERIC)";
 res=sqlite3_exec(db,sqlcreate,NULL,NULL,&errmsg);
if(res!=0){
 perror("建立数据表失败");
  exit(EXIT_FAILURE);
}

//插入100000条数据
int num=0;
struct timeval tv;
gettimeofday (&tv , NULL);
 long old=tv.tv_sec;
while(num<100000){
const char* sqlinsert="insert into call_list values ($num,1,2,'new',4,5,6)";
res=sqlite3_exec(db,sqlinsert,NULL,NULL,&errmsg);//插入时不需要用到回调函数
if(res!=0){
  perror("插入失败");
  exit(EXIT_FAILURE);
}
num++;
}

gettimeofday(&tv,NULL);
printf("插入100000条数据的时间为:%d秒/n",(tv.tv_sec-old));

//更新
const char* sqlupdate="update call_list set id=00001000 where id=10001";
res=sqlite3_exec(db,sqlupdate,NULL,NULL,&errmsg);
if(res!=0){
  perror("更新数据失败");
  exit(EXIT_FAILURE);
}
//删除
const char* sqldelete="delete from call_list where id=1000";
res=sqlite3_exec(db,sqldelete,NULL,NULL,&errmsg);
if(res!=0){
  perror("删除数据失败");
  exit(EXIT_FAILURE);
}

//查询
const char* sqlquery="select * from call_list";
res=sqlite3_exec(db,sqlquery,&_call_back,NULL,&errmsg);

if(res!=0){
  printf("%s/n",errmsg);
  perror("执行失败/n");
  exit(EXIT_FAILURE);
}
res=sqlite3_close(db);
if(res!=0){
  perror("数据库关闭失败");
  exit(EXIT_FAILURE);
}
exit(EXIT_SUCCESS);

}

int _call_back(void* arg,int argc,char**argv,char**cname){
   int i; //二重指针可以看成指针数组
  for(i=0;i<argc;i++){
   printf("%s=%s/n",cname[i],argv[i]);
}
 return 0;
}
编译与运行:
gcc -o sql sql.c -lsqlite3
可以看到:插入100000万条数据,仅需要542秒。因此,SQLite数据库非常的快。
总之,SQLite数据库对于小型应用程序的开发是非常高效的,常用于手机(Android),PDA中。
  • 0
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值