嵌入式学习39-程序创建数据库及查找

1.sqlite3_open

int sqlite3_open(

const char *filename, /* Database filename (UTF-8) */

sqlite3 **ppDb /* OUT: SQLite db handle */

);

功能:

打开 数据库文件(创建一个数据库连接)

参数:

filename : 数据库文件路径

ppDb : 操作 数据库指针 存放空间的首地址

返回值:

成功 返回 SQLITE_OK

失败 返回 错误码

2.sqlite3_close

int sqlite3_close(sqlite3*);

功能:

关闭 数据库连接

3.sqlite3_exec

int sqlite3_exec(

sqlite3*, /* An open database */

const char *sql, /* SQL to be evaluated */

int (*callback)(void*,int,char**,char**), /* Callback function */

void *, /* 1st argument to callback */

char **errmsg /* Error msg written here */

);

功能:

执行一条SQL语句

参数:

sqlite3*: 数据库 句柄

句柄: 是一个用来 标识对象 或者项目 的**标识符**,可以用来描述窗体、文件等 还有注意 句柄(Handle)**** 不是常量

sql: 要执行的 SQL语句 字符串首地址

callback: (回调函数) 只有select 时才会使用 (匹配数据) 其余 调用时传递 NULL

void*: 给 回调函数传参

errmsg: 出错信息 存放空间首地址 (使用完毕后使用sqlite3_free释放空间)

返回值:

成功 返回 SQLITE_OK

失败返回错误码

callback

strstr:子字符串查找

strstr函数声明:

char *strstr( const char * str1 , const char * str2 );

练习:

实现将dict.txt文件中的所有单词和含义插入到数据库中

5.调试段错误 :

1.根据给定链接设置系统允许生成core 文件

2.编译代码时加入**-g** 选项

gcc filename.c -g -lsqlite3

3.执行代码让代码产生段错误(会生成一个包含错误信息的core文件)

4.使用gdb调试core文件

gdb a.out core

5.可以直接看到产生段错误的代码的位置

6.html

meta:设置编码格式

相关推荐
weixin_56899606几秒前
Bootstrap中.d-none类在不同分辨率下的高级用法
jvm·数据库·python
qq_20690139几秒前
golang如何调用Twilio语音短信API_golang Twilio语音短信API调用实战
jvm·数据库·python
m0_68450198几秒前
c++如何将宽字符串wstring输出到UTF-8文件_C++17编码转换【附源码】
jvm·数据库·python
m0_748920362 分钟前
怎么在Navicat批量导入多个JSON数据_快速合并数据技巧
jvm·数据库·python
_张一凡4 分钟前
【大语言模型学习】2026年十大LLM训练数据集汇总
人工智能·学习·语言模型·aigc·大模型训练·llm数据集
2201_761040595 分钟前
mysql如何优化重复索引_mysql冗余索引查找与处理
jvm·数据库·python
别具匠心6 分钟前
嵌入式微型数据库-FlashDB
数据库·经验分享·笔记·学习·嵌入式实时数据库
yejqvow127 分钟前
如何分析RAC启动挂起_crond与ohasd进程启动依赖链排查
jvm·数据库·python
Alice-YUE9 分钟前
【前端面试之ai概念】大白话讲清 Agent、MCP、Skill、Function Calling、RAG
前端·人工智能·学习·aegnt
2401_8359568110 分钟前
c++怎么解析二进制存储的BMP位图调色板数据及每一行的像素偏移【详解】
jvm·数据库·python