SQlite3 是轻量级的嵌入式关系型数据库
适合场景:SQLite3 适合数据量不大(通常 < 10GB)、并发访问不高的场景
创建 / 打开数据库
sqlite3 test.db # 打开或创建 test.db 数据库
创建表
CREATE TABLE users (id INT PRIMARY KEY, name TEXT, age INT);
插入数据:
INSERT INTO users VALUES (1, 'Alice', 25);
INSERT INTO users VALUES (2, 'Bob', 30);
查询数据
SELECT * FROM users; # 输出所有用户
SELECT name FROM users WHERE age > 28; # 查询年龄>28的用户
退出 :输入 .quit 或 .exit
C 语言 API 编程:
1.包含头文件并链接库
#include <sqlite3.h>
// 编译时链接:-lsqlite3 或直接编译 sqlite3.c 源码
2.打开数据库
sqlite3 *db;
int ret = sqlite3_open("test.db", &db); // 打开数据库,db 为句柄
if (ret != SQLITE_OK) {
fprintf(stderr, "无法打开数据库: %s\n", sqlite3_errmsg(db));
return -1;
}
3.执行 SQL 语句(如创建表、插入数据)
const char *create_sql = "CREATE TABLE IF NOT EXISTS users (id INT, name TEXT);";
char *err_msg = NULL;
ret = sqlite3_exec(db, create_sql, NULL, NULL, &err_msg); // 执行 SQL
if (ret != SQLITE_OK) {
fprintf(stderr, "创建表失败: %s\n", err_msg);
sqlite3_free(err_msg); // 释放错误信息
}
4.查询数据(使用回调函数处理结果)
// 回调函数:每查询到一行数据就会被调用
static int callback(void *data, int argc, char **argv, char **col_name) {
for (int i = 0; i < argc; i++) {
printf("%s = %s\n", col_name[i], argv[i] ? argv[i] : "NULL");
}
return 0;
}
const char *select_sql = "SELECT * FROM users;";
ret = sqlite3_exec(db, select_sql, callback, NULL, &err_msg); // 执行查询,回调处理结果
5.关闭数据库
sqlite3_close(db); // 关闭数据库句柄
- 并发限制:SQLite3 写操作会锁定整个数据库(读操作可并发),高并发写场景(如多用户同时写入)不适用,适合单用户或低并发场景。