C语言封装sqlite3_API

这篇博客介绍了如何在C语言中使用sqlite3_API来执行SQL语句,特别是插入、更新、创建和删除操作。文章通过一个示例展示了如何执行此类操作,并强调了在执行后释放资源的重要性。
摘要由CSDN通过智能技术生成

//执行类似insert,update,create,drop这些不需要结果的sql语句。

int executeNoQuery(sqlite3 *db,const char *sql)
 {
    sqlite3_stmt *pstmt = NULL;
 
     if(sqlite3_prepare_v2(db,sql,strlen(sql),&pstmt,NULL)  !=  SQLITE_OK)
     {
         if(pstmt != NULL)
             sqlite3_finalize(pstmt);
        fprintf(stderr,"%s\n",sqlite3_errmsg(db));
         return -1;
     }
     if(sqlite3_step(pstmt)  !=  SQLITE_DONE)
     {
         sqlite3_finalize(pstmt);
         fprintf(stderr,"%s\n",sqlite3_errmsg(db));
         return -1;
    }
     if(pstmt != NULL)
         sqlite3_finalize(pstmt);
     return 0;
 }

//执行select查询语句
void executeWithQuery(sqlite3 *db,char ***result,int *col,const char *sql)
  {
      int ret,row;
 
在Linux下使用C语言封装SQLite可以通过SQLite提供的C API来实现。SQLite是一个轻量级、嵌入式的数据库引擎,适用于移动设备和单用户应用程序。下面是使用C语言封装SQLite的基本步骤: 1. 安装SQLite库:在Linux上安装SQLite库可以通过包管理器(如apt、yum)进行安装,或者从SQLite官方网站下载源代码进行编译安装。 2. 包含SQLite头文件:在C语言代码中包含SQLite的头文件,例如:`#include <sqlite3.h>` 3. 打开数据库连接:使用`sqlite3_open()`函数打开与数据库的连接,并获取一个`sqlite3`结构体的指针。示例代码如下: ```c sqlite3 *db; int rc = sqlite3_open("database.db", &db); if (rc != SQLITE_OK) { // 处理连接失败的情况 } ``` 4. 执行SQL语句:可以使用`sqlite3_exec()`函数执行SQL语句,该函数可以处理任意类型的SQL语句,包括查询、插入、更新和删除等。示例代码如下: ```c const char* sql = "CREATE TABLE IF NOT EXISTS students (id INTEGER PRIMARY KEY, name TEXT, age INT)"; rc = sqlite3_exec(db, sql, 0, 0, 0); if (rc != SQLITE_OK) { // 处理SQL语句执行失败的情况 } ``` 5. 处理查询结果:可以使用`sqlite3_exec()`函数的第三个参数来指定一个回调函数,在查询时调用该函数处理查询结果。示例代码如下: ```c int callback(void* data, int argc, char** argv, char** column_names) { for (int i = 0; i < argc; ++i) { printf("%s = %s\n", column_names[i], argv[i] ? argv[i] : "NULL"); } printf("\n"); return 0; } const char* sql = "SELECT * FROM students"; rc = sqlite3_exec(db, sql, callback, 0, 0); if (rc != SQLITE_OK) { // 处理SQL语句执行失败的情况 } ``` 6. 关闭数据库连接:使用`sqlite3_close()`函数关闭与数据库的连接。示例代码如下: ```c sqlite3_close(db); ``` 通过上述步骤,可以在Linux下使用C语言封装SQLite,实现对数据库的增删改查等操作。当然,这只是SQLite的基本使用方法,还有更多高级的特性和操作可以进一步探索。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值