SQlite3

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);  // 关闭数据库句柄
  1. 并发限制:SQLite3 写操作会锁定整个数据库(读操作可并发),高并发写场景(如多用户同时写入)不适用,适合单用户或低并发场景。
相关推荐
兵慌码乱10 小时前
面向桌面端的资产管理系统分层架构设计与核心模块实现
python·系统架构·sqlite·pyqt5·数据库设计·桌面应用开发·mvc架构
Nturmoils20 小时前
订单列表慢查询,先看 WHERE、ORDER BY 和 LIMIT
数据库
渣波1 天前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端
兵慌码乱1 天前
基于Python+PyQt5+SQLite的药房管理系统实现:事务一致性与界面解耦全流程解析
python·sqlite·信号与槽·pyqt5·数据库设计·桌面应用开发·事务处理
倔强的石头_2 天前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库
倔强的石头_5 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
冬奇Lab5 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence6 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
无响应de神6 天前
三、用户与权限管理
数据库·mysql
麦聪聊数据7 天前
数据服务化时代:企业数据能力输出的核心路径
数据库