嵌入式数据库sqlite测试程序

       继上篇对嵌入式数据库sqlite的移植和注意项,以及使用命令行测试之后,本篇对其进行了更进一步的程序测试,以备近期在项目中使用。测试程序及说明如下:

/**************** 相关函数说明 ******************/
/*  (1)sqlite3_open的函数原型说明:
int sqlite3_open
(const char *filename,   // Database filename (UTF-8) sqlite3 **ppDb          // OUT: SQLite db handle 
);
*//*  (2)sqlite3_exec的函数原型说明:
int sqlite3_exec
(sqlite3*, 			// An open database const char *sql, 	// SQL to be executed sqlite_callback, 	// Callback function void *, 			// 1st argument to callback function char **errmsg 		// Error msg written here 
);*//*  (3)查询数据
int sqlite3_get_table
(sqlite3*, const char *sql, char ***result,  //result中是以数组的形式存放你所查询的数据,首先是表名,再是数据。int *nrow,       //nrow ,ncolumn分别为查询语句返回的结果集的行数,列数,int *ncolumn,    //没有查到结果时返回0char **errmsg
); */ /******************* SQLite数据库测试 *******************/
#include <stdio.h>
#include <stdlib.h>#include "sqlite3.h"#define _DEBUG_ 1int main(int argc, char *argv[])
{sqlite3 *db = NULL;         //数据库const char *sql = 0;char *zErrMsg = 0;          //错误信息储存int nrow = 0, ncolumn = 0;  //行和列char **azResult; 	        //二维数组存放结果int rc = 0;int i = 0;//打开指定的数据库文件,如果不存在将创建一个同名的数据库文件rc = sqlite3_open("rtu_data.db", &db);if( rc ){fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));sqlite3_close(db);return 1;}elseprintf("Open a sqlite3 database named rtu_data.db successfully!\n");//创建一个表,如果该表存在,则不创建,并给出提示信息,存储在 zErrMsg 中sql = "create table data_table(rtuID, registerNum, data);";sqlite3_exec(db, sql, 0, 0, &zErrMsg);#if _DEBUG_printf("zErrMsg = %s \n", zErrMsg);
#endif//插入数据: 2种方法 sql = "insert into data_table(rtuID, registerNum, data) values(01, 0001, 1);";sqlite3_exec(db, sql, 0, 0, &zErrMsg);sql = "insert into \"data_table\" values(02, 0002, 2.0);";sqlite3_exec(db, sql, 0, 0, &zErrMsg);sql = "select * from data_table;";sqlite3_get_table(db, sql, &azResult, &nrow, &ncolumn, &zErrMsg);printf("row=%d, column=%d\n", nrow, ncolumn);printf("\nThe result of querying is:\n");for(i=0; i<(nrow + 1) * ncolumn; i++)printf("azResult[%d] = %s\n", i, azResult[i]);//释放掉 azResult 的内存空间sqlite3_free_table(azResult);#if _DEBUG_printf("zErrMsg = %s \n", zErrMsg);
#endifsqlite3_close(db); //关闭数据库return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/pingmian/88066.shtml
繁体地址,请注明出处:http://hk.pswp.cn/pingmian/88066.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【学习篇】SQL复杂查询学习

要求&#xff1a;能对千万行级别的大表优化读写效率。 难点&#xff1a;如何创建千万行级别的大表 MySQL数据库的高效查询不仅依赖于合理的表结构和索引设计&#xff0c;还需要掌握高级查询技巧和性能优化方法。 数据表与数据表之间关系三种&#xff1a;实体之间关系 多对多…

Sequential Predictive Modeling of Clinical Trial Outcome with Meta-Learning解读

SPOT(Sequential Predictive Modeling of Clinical Trial Outcome with Meta-Learning)模型是用于临床试验结果预测的模型, 借鉴了模型无关元学习(MAML,Model-Agnostic Meta-Learning)的框架,将模型参数分为全局共享参数和任务特定参数,以平衡跨任务泛化与任务内适配:…

优先选择列表而非数组及泛型类型的使用

数组与泛型的核心差异 协变性与不变性 数组采用协变(covariant)类型规则:若Sub是Super的子类型,则数组类型Sub[]也是Super[]的子类型。这种设计允许以下代码通过编译: Object[] objectArray = new Long[1]; // 编译通过 objectArray[0

自动化Prompt生成平台的研发体系设计

一份轻松不啰嗦的自动化Prompt平台研发攻略 &#x1f4d1; 目录 一、项目背景二、平台整体架构设计三、核心功能模块解析四、自动化流程设计五、样式与跨平台规范六、总结与展望 一、项目背景 在大模型应用爆发的今天&#xff0c;不写Prompt的工程师&#xff0c;正在变成“写…

[Swarm] 上下文变量 | 接入function功能调用 | Mcp

第3章&#xff1a;上下文变量 欢迎回到swarm&#xff01; 在前两章中&#xff0c;我们学习了作为对话指挥者的Swarm框架和具备指令与技能的专用AI角色智能体。(智能体就相当于是给用户问题 已经写好了的提示词&#xff0c;在用户提问时自动加入&#xff0c;以此来给用户更好的…

【Unity开发】Unity实现第一人称视角与第三人称视角切换功能

一、效果展示 第三人称视角&#xff1a;固定摄像机&#xff0c;无任何操作 第一人称视角&#xff1a;用户可以通过wsad进行前后左右移动&#xff0c;qe进行上升下降操作 不同视角之间切换会有一个过渡动画&#xff0c;切换第一视角的初始位置始终为原点&#xff08;0,0,0&am…

2025全球数字经济大会—云智算安全论坛暨第三届“SecGo论坛”成功召开!共筑安全新生态

2025年7月3日&#xff0c;由全球数字经济大会组委会主办&#xff0c;中国信息通信研究院、中国通信标准化协会承办的全球数字经济大会—云智算安全论坛暨第三届“SecGo论坛”在京召开。北京市经济和信息化局副局长顾瑾栩、中国通信标准化协会副理事长兼秘书长代晓慧、中国信通院…

KingbaseES聚焦产品上线:金仓数据库在线体验平台上线,开启数据库实践新征程

KingbaseES聚焦产品上线&#xff1a;金仓数据库在线体验平台上线&#xff0c;开启数据库实践新征程KingbaseES 在线体验平台是为数据库使用者、开发者、架构师及 DBA 打造的轻量化实践平台&#xff0c;无需本地安装数据库环境&#xff0c;通过浏览器即可快速上手&#xff0c;降…

LLMs之DeepSeek:AI模型市场深度分析:DeepSeek的挑战与机遇,模型市场份额、Token经济学与未来发展

LLMs之DeepSeek&#xff1a;AI模型市场深度分析&#xff1a;DeepSeek的挑战与机遇&#xff0c;模型市场份额、Token经济学与未来发展 导读&#xff1a;该文章主要分析了中国大语言模型DeepSeek R1发布150天后的市场表现、Token经济学的影响以及AI模型市场的竞争格局。文章指出&…

服装零售企业跨区域运营难题破解方案

在服装零售行业&#xff0c;本地化业务系统因承载库存、销售等核心数据&#xff0c;成为众多企业的选择。然而对于门店分布广、规模较大的服装销售商而言&#xff0c;总部系统与各地门店的远程连接却面临挑战&#xff1a;员工远程办公效率低、POS机数据同步滞后、跨区域监管难度…

- 思考小记

对于 分布式系统&#xff0c;我还是抱有敬畏之心的&#xff0c;因为其内容过于庞大&#xff1b;我在学习基础编程的时候走过一个最大的弯路就是过度追求技术而忽视了基础编码能力&#xff0c;当时在学习springboot的时候&#xff0c;觉得那些新内容都是那么新奇高大上&#xff…

装备制造数字孪生底座平台

在《中国制造2025》和《“十四五”智能制造发展规划》的推动下&#xff0c;数字孪生技术被7次重点提及&#xff0c;成为装备制造业智能化升级的核心战略。从航空航天到重型机械&#xff0c;从设计验证到运维优化&#xff0c;数字孪生底座平台正通过“虚实映射”与“实时交互”&…

Redis构建缓存服务器

环境信息&#xff1a; redis-master----192.168.12.135 redis-slave-1-----192.168.12.136 redis-slave-2-----192.168.12.137 单机版Redis 安装Redis yum install -y gcc make jemalloc jemalloc-devel gcc-c wget tcl yum groupinstall -y "Development Tools" wge…

vscode python debugger关闭编辑器内的变量值自动显示

vscode 的python debugger调试器的最新版本2025.8.0, 会默认把变量的值显示出来, 如下图所示关闭的方法: 打开vscode的settings.json, 左下角点击齿轮按钮, 选择setting(设置), 然后在右上角三个按钮最中间的那个(open setting json), 输入 "debug.inlineValues": &q…

App爬虫工具篇-appium配置

接着上篇文章App爬虫工具篇-Appium安装,安装好了之后,还是不够的,要让其能够驱动手机端,还需要配置。这节课就深入说说如何配置Appium。 安卓手机 如果我们要使用 Android 设备做 App 抓取的话,还需要下载和配置 Android SDK,这里推荐直接安装 Android Studio,其下载地…

SpringAI系列 - 基于Spring AI 1.0.0 的AI助手实现示例

目录 一、基于 Spring AI 1.0.0 的AI助手实现示例二、AI助手架构设计2.1 系统范围与上下文 C12.2 容器图 C22.3 AI助手组件图 C3三、注意事项四、快速启动五、如何启用MCP一、基于 Spring AI 1.0.0 的AI助手实现示例 结合前文系列的介绍,本专栏提供了一个基于Spring AI 1.0.0…

电池预测 | 第33讲 Matlab基于CNN-LSTM-Attention的锂电池剩余寿命预测,附锂电池最新文章汇集

电池预测 | 第33讲 Matlab基于CNN-LSTM-Attention的锂电池剩余寿命预测&#xff0c;附锂电池最新文章汇集 目录电池预测 | 第33讲 Matlab基于CNN-LSTM-Attention的锂电池剩余寿命预测&#xff0c;附锂电池最新文章汇集预测效果基本描述程序设计参考资料源码地址&#xff1a; 电…

软考(软件设计师)数据库原理-SQL

一、SQL基本数据类型 SQL 数据类型速查表类别数据类型说明范围/示例适用场景整数类型INT / INTEGER标准整数类型-2 到 2-1 (-2,147,483,648 到 2,147,483,647)ID、年龄、数量等SMALLINT小范围整数-32,768 到 32,767小范围数值BIGINT大范围整数-2⁶ 到 2⁶-1大额订单号、时间戳T…

docker 安装数据集成平台 Apache SeaTunnel 服务

获取官方镜像 从 Docker Hub 上拉取最新的 Apache SeaTunnel 镜像&#xff1a; docker pull apache/seatunnel:latest创建目录 sudo mkdir -p /data/{conf,logs} # 需要 root 权限创建 /data 目录 sudo chown -R $USER:$USER /data # 将目录权限给当前用户&#xff08;可选&a…

数据结构:数组:线性查找(Linear Search)

目录 什么是线性查找&#xff1f; 时间复杂度分析 &#x1f9e0; 线性查找的优化 方法一&#xff1a;Move to Front&#xff08;哨兵&#xff09; 方法二&#xff1a;Transportation&#xff08;向前交换一步&#xff09; 什么是线性查找&#xff1f; 我们先问&#xf…