C/C++ 通过SQLiteSDK增删改查

简介: 这些步骤总结了如何在C/C++中使用SQLite SDK进行数据库的增删改查操作。良好的错误处理、安全的SQL查询以及资源管理对于保持代码的健壮性是非常重要的。

在C/C++中使用SQLite SDK进行增删改查(CRUD)操作是一种常见的数据库交互形式。SQLite是一个轻量级的数据库引擎,它不需要一个独立的服务器处理,直接以库的形式嵌入到应用程序中。下面是如何在C/C++中使用SQLite SDK进行基本的数据库操作的专业指引。

准备工作

在开始编码之前,确保你的开发环境中已经安装了SQLite的开发库文件。你可以从SQLite的官方网站下载最新的源代码或预编译的库,并将其包含到你的项目中。

打开/关闭数据库

首先,要进行任何操作,需要打开数据库。在C/C++中使用 sqlite3_open函数可以打开数据库。如果数据库文件不存在,SQLite将会自动创建一个。

#include <sqlite3.h>

sqlite3 *db;
int rc;

rc = sqlite3_open("example.db", &db);
if (rc != SQLITE_OK) {
    fprintf(stderr, "无法打开数据库: %s\n", sqlite3_errmsg(db));
    sqlite3_close(db);
}

// ... 进行数据库操作 ...

sqlite3_close(db);

创建表格

使用 sqlite3_exec函数,可以执行任何SQL语句,例如创建一个新表。

const char *sql = "CREATE TABLE IF NOT EXISTS Students (Id INTEGER PRIMARY KEY, Name TEXT NOT NULL, Age INTEGER)";

rc = sqlite3_exec(db, sql, 0, 0, &errMsg);
if (rc != SQLITE_OK) {
    fprintf(stderr, "SQL错误: %s\n", errMsg);
    sqlite3_free(errMsg);
}

插入数据

插入数据也使用 sqlite3_exec,但通常我们使用 sqlite3_prepare_v2sqlite3_bind系列函数和 sqlite3_step来进行参数化查询,并预防SQL注入。

const char *sql = "INSERT INTO Students (Name, Age) VALUES (?,?)";
sqlite3_stmt *stmt;

rc = sqlite3_prepare_v2(db, sql, -1, &stmt, NULL);
if (rc != SQLITE_OK) {
    fprintf(stderr, "准备语句失败: %s\n", sqlite3_errmsg(db));
}

sqlite3_bind_text(stmt, 1, "张三", -1, SQLITE_STATIC);
sqlite3_bind_int(stmt, 2, 20);

rc = sqlite3_step(stmt);
if (rc != SQLITE_DONE) {
    fprintf(stderr, "执行语句失败: %s\n", sqlite3_errmsg(db));
}

sqlite3_finalize(stmt);

查询数据

对于查询操作,也是通过 sqlite3_prepare_v2sqlite3_stepsqlite3_column函数来完成的。

const char *sql = "SELECT * FROM Students";
sqlite3_stmt *stmt;

rc = sqlite3_prepare_v2(db, sql, -1, &stmt, NULL);
if (rc != SQLITE_OK) {
    fprintf(stderr, "准备语句失败: %s\n", sqlite3_errmsg(db));
}

while ((rc = sqlite3_step(stmt)) == SQLITE_ROW) {
    int id = sqlite3_column_int(stmt, 0);
    const unsigned char *name = sqlite3_column_text(stmt, 1);
    int age = sqlite3_column_int(stmt, 2);

    printf("Id: %d, Name: %s, Age: %d\n", id, name, age);
}

sqlite3_finalize(stmt);

更新数据

更新数据与插入数据类似,使用参数化查询。

const char *sql = "UPDATE Students SET Age = ? WHERE Id = ?";
sqlite3_stmt *stmt;

rc = sqlite3_prepare_v2(db, sql, -1, &stmt, NULL);
if (rc != SQLITE_OK) {
    fprintf(stderr, "准备语句失败: %s\n", sqlite3_errmsg(db));
}

sqlite3_bind_int(stmt, 1, 21); // 设置新的年龄
sqlite3_bind_int(stmt, 2, 1);  // 设置要更新的ID

rc = sqlite3_step(stmt);
if (rc != SQLITE_DONE) {
    fprintf(stderr, "执行语句失败: %s\n", sqlite3_errmsg(db));
}

sqlite3_finalize(stmt);

删除数据

删除数据也是使用 sqlite3_prepare_v2sqlite3_bind函数。

const char *sql = "DELETE FROM Students WHERE Id = ?";
sqlite3_stmt *stmt;

rc = sqlite3_prepare_v2(db, sql, -1, &stmt, NULL);
if (rc != SQLITE_OK) {
    fprintf(stderr, "准备语句失败: %s\n", sqlite3_errmsg(db));
}

sqlite3_bind_int(stmt, 1, 1); // 设置要删除的ID

rc = sqlite3_step(stmt);
if (rc != SQLITE_DONE) {
    fprintf(stderr, "执行语句失败: %s\n", sqlite3_errmsg(db));
}

sqlite3_finalize(stmt);

每个从SQLite返回的错误码都可以用来判断操作是否成功,如果操作未成功,可以使用 sqlite3_errmsg函数获取错误信息。务必注意在操作完成后,使用 sqlite3_finalize来清理准备的语句和 sqlite3_close来关闭数据库连接。

这些步骤总结了如何在C/C++中使用SQLite SDK进行数据库的增删改查操作。良好的错误处理、安全的SQL查询以及资源管理对于保持代码的健壮性是非常重要的。

目录
相关文章
|
3月前
|
SQL 数据库 开发工具
C/C++通过SQLiteSDK增删改查
记住,在实际开发过程中要对所有数据库操作进行适当的错误检查和资源管理,以避免内存泄漏或其他潜在问题。在处理错误时,确保提供适当的反馈并做必要的清理。
56 0
|
C++
使用C++编写一个AVL的增删改查代码并附上代码解释
使用C++编写一个AVL的增删改查代码并附上代码解释
96 0
|
C++
单链表的增删改查等操作(C++语言)
单链表的增删改查等操作(C++语言)
108 0
|
数据库 C++ 数据库管理
|
SQL Oracle 关系型数据库
什么是Pro*C/C++,嵌入式SQL,第一个pro*c程序,pro*c++,Makefile,Proc增删改查
 1 什么是Pro*C/C++ 1、通过在过程编程语言C/C++中嵌入SQL语句而开发出的应用程序 2、什么是嵌入式SQL 1、在通用编程语言中使用的SQL称为嵌入式SQL 2、在SQL标准中定义了很多中语言的嵌入式SQL 3、各个厂
1878 0
|
23天前
|
存储 编译器 C语言
【c++丨STL】string类的使用
本文介绍了C++中`string`类的基本概念及其主要接口。`string`类在C++标准库中扮演着重要角色,它提供了比C语言中字符串处理函数更丰富、安全和便捷的功能。文章详细讲解了`string`类的构造函数、赋值运算符、容量管理接口、元素访问及遍历方法、字符串修改操作、字符串运算接口、常量成员和非成员函数等内容。通过实例演示了如何使用这些接口进行字符串的创建、修改、查找和比较等操作,帮助读者更好地理解和掌握`string`类的应用。
36 2
|
29天前
|
存储 编译器 C++
【c++】类和对象(下)(取地址运算符重载、深究构造函数、类型转换、static修饰成员、友元、内部类、匿名对象)
本文介绍了C++中类和对象的高级特性,包括取地址运算符重载、构造函数的初始化列表、类型转换、static修饰成员、友元、内部类及匿名对象等内容。文章详细解释了每个概念的使用方法和注意事项,帮助读者深入了解C++面向对象编程的核心机制。
82 5
|
1月前
|
存储 编译器 C++
【c++】类和对象(中)(构造函数、析构函数、拷贝构造、赋值重载)
本文深入探讨了C++类的默认成员函数,包括构造函数、析构函数、拷贝构造函数和赋值重载。构造函数用于对象的初始化,析构函数用于对象销毁时的资源清理,拷贝构造函数用于对象的拷贝,赋值重载用于已存在对象的赋值。文章详细介绍了每个函数的特点、使用方法及注意事项,并提供了代码示例。这些默认成员函数确保了资源的正确管理和对象状态的维护。
79 4
|
1月前
|
存储 编译器 Linux
【c++】类和对象(上)(类的定义格式、访问限定符、类域、类的实例化、对象的内存大小、this指针)
本文介绍了C++中的类和对象,包括类的概念、定义格式、访问限定符、类域、对象的创建及内存大小、以及this指针。通过示例代码详细解释了类的定义、成员函数和成员变量的作用,以及如何使用访问限定符控制成员的访问权限。此外,还讨论了对象的内存分配规则和this指针的使用场景,帮助读者深入理解面向对象编程的核心概念。
86 4
|
2月前
|
存储 编译器 对象存储
【C++打怪之路Lv5】-- 类和对象(下)
【C++打怪之路Lv5】-- 类和对象(下)
31 4