linux下sqlite3的使用实例(c语言)

本文介绍了在Linux系统中如何安装sqlite3以及使用C语言进行数据库操作,包括创建数据库、插入数据、查看表内容和删除数据。通过sqlite3_open、sqlite3_exec等函数进行数据库交互,并提供代码实例说明。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.安装数据库

Linux 下安装sqlite3 需要两个个命令 即可:
(1)sudo apt-get install sqlite
(2)apt-get install libsqlite3-dev

2.相关函数

1. sqlite3_open 用来打开一个数据库

#include <sqlite3.h>

int sqlite3_open(const char *dbname, sqlite3 **db)

第一个参数dbname:数据库的名称
第二个参数 db:数据库的句柄

2.sqlite3_close 关闭一个数据库

int sqlite3_close(sqlite3 *db)

3.sqlite3_exec 用来执行sqlite3 语句

int sqlite_exec(sqlite *db, const char *sql,int (* callback)(void *int, char **, char **),void *, char **errmsg);

第一个参数db:与之前相同;
第二个参数sql:SQL语句;以\0结尾。
第三个参数callback:回调函数;当这条语句执行之后,sqlite3会去调用你提供的这个函数。通常设为NULL。
第四个参数void*是你所提供的指针,你可以传递任何一个指针参数到这里,这个参数最终会传到回调函数里面,如果不需要传递指针给回调函数,可以填NULL。
第五个参数char** errmsg 是错误信息。

说明:通常,sqlite3_callback和它后面的void*这两个位置都可以填NULL。填NULL表示你不需要回调。比如你做insert 操作,做delete操作,就没有必要使用回调。而当你做select 时,就要使用回调,因为sqlite3 把数据查出来,得通过回调告诉你查出了什么数据。虽然回调显得代码整齐,但有时候你还是想要非回调的select
查询。这可以通过sqlite3_get_table 函数做到。

4.sqlte3_get_table 执行sql的查询功能

int sqlite3_get_table(sqlite3 *db, const char *zSql,char **pazResult, int *pnRow,int *pnColumn);

第一个参数db:数据库句柄
第二个参数zSql:sqlite3的语句,跟sqlite3_exec 里的sql 是一样的。是一个很普通的以\0结尾的char*字符串。
第三个参数pazResult:查询的结果,它依然一维数组(不要以为是二维数组,更不要以为是三维数组)。它内存布局是:字段名称,后面是紧接着是每个字段值。
第四个参数pnRow:结果集的列数,即查出多少行
第五个参数errmsg:错误信息

注意:如果提供了errmsg,用来创建错误消息的内存是在堆上分布的。 故在调用后,应该检查一下是否为null值,如果有错误发生,使用sqlite3_free()释放errmsg占用的内存。

3.代码实例

3.1创建一个数据库

#include <stdio.h>
#include <string.h>
#include <sqlite3.h>
#include <errno.h>
#include <stdlib.h>

int main(int argc, char **argv)
{
   
          sqlite3     *db=NULL;
          int          rc = -1
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值