如何在Linux下用C语言 *** 作数据库sqlite3

如何在Linux下用C语言 *** 作数据库sqlite3,第1张

#include<sqlite3.h>

int main(void)

{

sqlite3 *db

char buf[1024]={0}

if(sqlite3_open("数据的路径",&db)

{

printf("数据库打开失败\n")

return -1

}

sprintf(buf,"select * from 表格名称")

if(sqlite3_exec(db,buf,0,0,0)!=SQLITE_OK)

{

printf("执行失败\n")

return -1

}

sqlite3_close(db)

return 0

}

上面这些只是个大体的 *** 作

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)建立数据库sqlite3data.sqlite3在当前目录下建立了名为data.sqlite3的数据库。(2)建立数据表createtablecall_list(idINTEGERPRIMARYKEY,typeNUMERIC,telnumNUMERIC,bttimeTEXT,tcountNUMERIC,charge_rateNUMERIC,charge_sumNUMERIC)建立了名为call_list的数据表,有7个字段,分别为id,type,telnum,bttime,tcount,charge_sum.charge_rate.(3)向数据表中插入数据insertintocall_listvalues($num,1,2,'new',4,5,6)(4)查询数据表中的数据select*fromcall_list(5)修改call_list表中的数据updatecall_listsetid=00001000whereid=10001(6)删除表中的数据记录deletefromcall_listwhereid=1000(7)SQlite中的其它常用命令.tables-列出所有的数据库中的数据表.schematablename-列出指定数据表的结构.quit-离开数据库(8)SQLite数据库的导入与导出a.将data.sqlite数据库的数据全部导出:sqlite3data.sqlite>.outputdd.sql>.dump这样,数据就保存在dd.sql的文件中,注意这个文件不是数据库,而是SQL语句。然后再把这些数据导入到另外一个数据库data1.sqlite数据库中。sqlite3data1.sqlite>.readdd.sql这样,数据就从data.sqlite数据库复制到data1.sqlite数据库中去了。b.将数据表中的数据导出到a.txt中去.outputa.txt//输出重定向到a.txtselect*fromcall_listc.将导出的表中的数据导入到另一个数据库的新建的表中去如:当从data.sqlite中的call_list表中导出了数据,再导入到另外一个数据库表call中去。首先建立表call.然后.importa.txtcall即可。3.C语言 *** 作Sqlite数据库API:intsqlite3_open(constchar*filename,sqlite3**ppdb)第一个参数用来指定数据库文件名。第二个参数是一个数据库标识符指针。如果打开数据库成功,则返回0,否则返回一个错误代码。intsqlite3_close(sqlite3*)传递的参数是数据库标识符指针用来关闭数据库, *** 作成功是返回0,否则返回一个错误代码。intsqlite3_errcode(sqlite3*db)constchar*sqlite3_errmsg(sqlite3*db)constchar*sqlite3_errmsg16(sqlite3*db)这三个函数都是返回错误信息,第一个函数返回的是最近调用数据库接口的错误代码,第二,第三个函数是返回最近调用数据库接口的错误信息。第二个函数返回的错误信息是用UTF-8编码的,第三个函数返回的错误信息是用UTF-16编码的。intsqlite3_exec(sqlite3*,constchar*sql,int(*callback)(void*,int,char**,char**),void*,**errmsg)这个函数非常重用,是用来执行SQLite数据库的SQL语句的。第一个参数是sqlite数据库标识符指针。第二个参数是要执行的SQL语句。第三个参数是一个回调函数,在执行查询 *** 作时用到,其它的 *** 作可以传空值即NULL。第四个参数是传递给回调函数第一个参数的实参。第五个参数是一个错误信息。回调函数:intcallback(void*,intargc,char**argv,char**cname)第一个参数是从sqlite3_exec传递过来的参数,可以为任意的类型。第二个参数是查询的列数。第三个参数是查询结果集的值。第四个参数是列名。intsqlite3_get_table(sqlite3*db,constchar*sql,char***result,int*row,int*col,char**errmsg)这个函数主要是用来查询的。第一个参数是数据库描述符指针第二个参数是SQL语句。第三个参数是查询的结果集。第四个参数是结果集中的行数。第五个参数是结果集中的列数。第六个参数是错误信息。它查询出的行数是从字段名开始的。即第0行是字段名。实例:/**本例主要实现用Sqlite的回调函数进行查询intsqlite3_exec(sqlite3*,constchar*sql,int(*callback)(void*,int,char**,char**),void*,errmsg)第一个参数是数据库标识符第二个参数是要执行的sql命令第三个参数是回调函数第四个参数是回调函数的第一个参数第五个参数是用于指示错误信息其中回调函数的形式:int_sql_callback(void*arg,intargc,char**argv,char**cname)第二个参数指示结果集中的列数第三个参数是保存结果集的字符串第四个参数是结果集中的列名**/#include#include#include#include#include#includeint_call_back(void*arg,intargc,char**argv,char**cname)intmain(){intresconstchar*dbfile="data.sqlite1"char*errmsg=NULLsqlite3*dbres=sqlite3_open(dbfile,&db)if(res!=0){perror("数据库打开失败")exit(EXIT_FAILURE)}//创建一张数据表constchar*sqlcreate="createtablecall_list(idINTEGERPRIMARYKEY,typeNUMERIC,telnumNUMERIC,bttimeTEXT,tcountNUMERIC,charge_rateNUMERIC,charge_sumNUMERIC)"res=sqlite3_exec(db,sqlcreate,NULL,NULL,&errmsg)if(res!=0){perror("建立数据表失败")exit(EXIT_FAILURE)}//插入100000条数据intnum=0structtimevaltvgettimeofday(&tv,NULL)longold=tv.tv_secwhile(num<100000){constchar*sqlinsert="insertintocall_listvalues($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))//更新constchar*sqlupdate="updatecall_listsetid=00001000whereid=10001"res=sqlite3_exec(db,sqlupdate,NULL,NULL,&errmsg)if(res!=0){perror("更新数据失败")exit(EXIT_FAILURE)}//删除constchar*sqldelete="deletefromcall_listwhereid=1000"res=sqlite3_exec(db,sqldelete,NULL,NULL,&errmsg)if(res!=0){perror("删除数据失败")exit(EXIT_FAILURE)}//查询constchar*sqlquery="select*fromcall_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,intargc,char**argv,char**cname){inti//二重指针可以看成指针数组for(i=0i

下载 sqlite3 库,放在项目文件夹中,包含 sqlite3.h 头文件,包含 sqlite3.lib 导入库,将 sqlite3.dll 复制到 .exe 所在目录。

代码如下:

#include <stdio.h>

#include <stdlib.h>

// 包含 sqlite3 头文件

#include "../sqlite-3.24.0/include/sqlite3.h"

// 添加 sqlite3 lib 库

#pragma comment(lib, "../sqlite-3.24.0/x86/sqlite3.lib")

int table_exist_callback(void *data, int argc, char **argv, char **azColName)

{

int val = atoi(argv[0])

if (val == 0) {

return -1

}

return 0

}

int print_callback(void *data, int argc, char **argv, char **azColName)

{

for (int i = 0 i < argc i++) {

printf("%s = %s\n", azColName[i], argv[i])

}

printf("\n")

return 0

}

int main()

{

sqlite3 *db = NULL

char *sql = NULL

char *errMsg = NULL

// 打开数据库

int ret = sqlite3_open("data.db", &db)

if (ret != SQLITE_OK) {

printf("打开数据失败,%s\n", sqlite3_errmsg(db))

exit(-1)

}

// 判断 students 是否存在,如果不存在,则创建表 students

sql = "select count(*) from sqlite_master where type='table' and name='students'"

ret = sqlite3_exec(db, sql, table_exist_callback, NULL, NULL)

if (ret != SQLITE_OK) {

// 创建 students 表

sql = "create table students(number varchar(10), name varchar(20), age integer)"

ret = sqlite3_exec(db, sql, NULL, NULL, &errMsg)

if (ret != SQLITE_OK) {

printf("创建表失败,%s.\n", errMsg)

sqlite3_close(db)

sqlite3_free(errMsg)

exit(-1)

}

}

// 插入数据到 students 表

sql = "insert into students(number, name, age) values('100001', 'Barry', 23)"

"insert into students(number, name, age) values('100002', 'Oliver', 33)"

ret = sqlite3_exec(db, sql, NULL, NULL, &errMsg)

if (ret != SQLITE_OK) {

printf("插入表数据失败,%s.\n", errMsg)

sqlite3_close(db)

sqlite3_free(errMsg)

exit(-1)

}

// 查询 students 表数据

sql = "select * from students"

ret = sqlite3_exec(db, sql, print_callback, NULL, &errMsg)

if (ret != SQLITE_OK) {

printf("查询数据失败,%s.\n", errMsg)

sqlite3_close(db)

sqlite3_free(errMsg)

exit(-1)

}

// 关闭数据库

sqlite3_close(db)

system("pause")

return 0

}

项目源码:网页链接


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/9895303.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-03
下一篇2023-05-03

发表评论

登录后才能评论

评论列表(0条)

    保存