Linux软件编程——数据库——自制小词典

一、数据库编程相关函数接口:

注:示例

ret = sqlite3_exec(pdb, cmdbuff, NULL, NULL, &perrmsg);

if (ret != SQLITE_OK)

{

fprintf(stderr, "sqlite_exec failed:%s\n", perrmsg);

sqlite3_free(perrmsg);

sqlite3_close(pdb);

return -3;

}

二、回调函数与查询逻辑

回调函数原型(固定格式,不能修改):

int callback(void *arg, int col_num, char **col_values, char **col_names);

  • argsqlite3_exec传入的ptmpmean(结构体指针),通过void*通用类型接收,内部强转为mean_t*
  • col_num:查询结果的列数(这里查含义列,所以是 1)。
  • col_values:查询结果的数值数组(col_values[0]就是含义)。
  • col_names:列名数组(col_names[0]含义)。

三、练习:利用数据库自制字典

1.access 函数功能 :检查当前进程对指定文件的访问权限(或文件是否存在)。

int access(const char *pathname, int mode);

  • 参数 1 pathname:要检查的文件路径(如 "dict.db")。
  • 参数 2 mode:检查模式(常用宏定义):
    • F_OK固定宏(值为 0),仅检查文件是否存在(不检查权限)。
    • R_OK:检查是否有读权限。
    • W_OK:检查是否有写权限。
    • X_OK:检查是否有执行权限。
  • 返回值:成功(满足检查条件)返回0,失败返回-1(并设置errno)。

2.dict.dbSQLite 数据库文件 (不是单纯的表格),文件里可以包含多个表(比如这里的dict表)。

3.primary key:标记该列为主键(值唯一且非空),用于唯一标识一行数据。

SQLite 中,integer primary key 列会自动自增, 插入时写NULL就会自动生成递增的整数值。

4.SQL 语句中\"%s\"\作用:

\转义字符 ,C 语言中,字符串用""包裹,如果字符串内部需要",必须加\转义,否则编译器会认为字符串提前结束。

5.fgets(tmpbuff, sizeof(tmpbuff), fp)读取一行数据 (直到遇到\n或文件结束),最多读sizeof(tmpbuff)-1个字符(避免缓冲区溢出)。

6.加载进度计算

  • fseek(fp, 0, SEEK_END):将文件指针移到文件末尾。
  • tlen = ftell(fp):获取文件总长度(字节数)。
  • rewind(fp):将文件指针移回开头。
  • clen = ftell(fp):每次读取一行后,获取当前指针位置,计算已加载比例:(double)clen / tlen * 100.0(百分比)。

7.printf 行缓存与 fflush

printf 行缓存与 fflush
  • printf行缓冲 :输出内容会先存在缓冲区,遇到\n或缓冲区满时才刷新到终端。
  • \r 是回车符:光标回到行首(不换行),所以printf("已加载:%.2lf\r", ...)会在同一行更新进度。
  • fflush(stdout):强制刷新标准输出缓冲区,让进度实时显示在终端(否则可能延迟显示)。
相关推荐
小马爱打代码3 小时前
Redis 集群方案详解:主从复制、哨兵、脑裂、分片集群和哈希槽
数据库·redis·哈希算法
海南java第二人4 小时前
ClickHouse 稀疏索引深度解析:为什么 OLAP 数据库不用 B-Tree?
数据库·clickhouse
Litluecat4 小时前
信创迁移:Oracle切换海量数据库,慢sql扫描
数据库·sql·oracle·信创·海量
消失在人海中5 小时前
Oracle的CURRENT REDO丢失,数据丢失风险分析
数据库·oracle
喵了几个咪5 小时前
选择第三方IAM还是自建权限体系?中小型后台系统权限架构决策指南
数据库·oracle·架构
Elastic 中国社区官方博客6 小时前
Kibana:使用 AI Chat 及 MCP 轻松创建 AI 原生仪表板
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·信息可视化
杨云龙UP7 小时前
Oracle Health Check巡检脚本使用SOP V2.0:从HTML原始报告→生成Word专业巡检报告→交付客户_2026-06-03
linux·运维·数据库·sql·oracle·报告·巡检
Database_Cool_7 小时前
Hudi 湖仓一体架构:阿里云 AnalyticDB MySQL 原生集成最佳实践
数据库·mysql·阿里云
我是一颗柠檬7 小时前
【Redis】发布订阅与消息队列Day8(2026年)
数据库·redis·后端·缓存