SQLite 数据库编程获取数据表达方式分析信息 | 学习笔记

简介: 快速学习 SQLite 数据库编程获取数据表达方式分析信息

开发者学堂课程【嵌入式之 RFID 开发与应用2020版:SQLite 数据库编程获取数据表达方式分析信息】学习笔记,与课程紧密联系,让用户快速学习知识。

课程地址:https://developer.aliyun.com/learning/course/665/detail/11237


SQLite 数据库编程获取数据表达方式分析信息

SQLite数据库编程获取数据表达方式分析信息

另一种方式是 get_table   sqlite3_get_table 函数:

int sqlite3_get_table(sqlite3*db,const char *sql,

char***resultp,

int *nrow,

int *ncolumn,

char **errmsg);

sal = "select * from info ; ";

sqlite3_get_table (db , sql , &result, &row , &col , &err) ;

if (err) {

printf ( "err : %s \n" ,err) ;

}

sqlite3_close (db);

return 0;

}

定义 result

int main (int argc , char **argv)

{

sqlite3 *db = NULL;

int ret;char *err =NULL;

char *sql;int row,col ,i;

char **result;

ret =sqlite3_open ( "stu . db " , &db ) ;

if(ret != SQLITE_OK) {

printf ( "open error\n " ) ;

return -1;

}

sal = "select * from info ; ";

sqlite3_get_table (db , sql , &result, &row , &col , &err) ;

if (err) {

printf ( "err : %s \n" ,err) ;

sqlite3_close (db);

return -1;

}

如果出错 return -1;如果没有出错,释放资源

//处理读取到的数据包信息

根据之前的课程,我们知道它的数据是一格一格存储的,这歌表的格数是行乘以列。

for (i=0;i<row*col;i++) {

/将 result 的结果都打印出来

printf ( "result [ %d]= %s \n" ,i ,result[i]);

}

Sqlite3_free_table(result);

sqlite3_close (db);

return 0;

}

执行查看效果:

edu@edu : sqlite$

edu@edu : sqlite$make; ./example

gcc -c example.c -o example.o -Wall

gcc example.o sqlite3.o -o example -wall -lpthread -ld

result[0]= id

result[1]= name

result[2]addr

result[3] = time

result[4] = date

result[5] = 119

result[6]= yy

result[7] = bj

result[8]= (null)

result[9]= (null)

result[10] = 102

result[11] = ls

result[12] = tj

result[13] = (null)

result[14] = (null)

。。。

result[22] = cd

result[23] = (null)

result[24]= (null)

result[25] = 105

result[26]= xw

result[27]= cq

result[28] = (null)

result[29] = (null)

result[30]= 107

result[31] = (null)

result[32] = (null)

result[33] = (null)

result[34] = (null)

result[35]= 108

result[36]= xx

result[37]= ty

result[38]= 08:01:40

result[39]= 2020-04-28

result[40]= 120

result[41]zz

result[42] = ts

result[43] = 09:55:00

result[44]= 2020-04-28

通过以上数据,col 其实是 5,行是 9 行,如果认为以上数据不方便查看,可以在代码中在加入一个 for 循环。

int main (int argc , char **argv)

{

sqlite3 *db = NULL;

int ret;char *err =NULL;

/再加入一个变量 j、定义索引

char *sql;int row,col,i,j,index=0;

char **result;

ret =sqlite3_open ( "stu . db " , &db ) ;

if(ret != SQLITE_OK) {

printf ( "open error\n " ) ;

return -1;

}

sal = "select * from info ; ";

sqlite3_get_table (db , sql , &result, &row , &col , &err) ;

if (err) {

printf ( "err : %s \n" ,err) ;

sqlite3_close (db);

return -1;

}

for (i=0;i<row;i++) {//col=5

printf(“第%d行:\n”,i);

for(j-=0;j<col;j++) {

因为i和j会归零,所以打印不能是i和j,所以要单独定义一个索引

printf ( "result [ %d]= %s \n" ,j ,result[index]);

}

Sqlite3_free_table(result);

sqlite3_close (db);

return 0;

}

运行查看效果:

第 0 行:

result[0]= id

result[1] = name

result[2] = addr

result[3] = time

result[4] = date

第 1 行:

result[0] = 119

result[1] = yy

result[2] = bj

result[3]= (null)

result[4] = (null)

第 2 行:

result[0]= 102

result[1]= ls

result[2]= tj

result[3] = (null)

result[4] = (null)

第 3 行:

result[0] = 110

result[1] = ww

result[2] = sh

result[3] = (null)

result[4] = (null)

通过以上方法,每一行数据单独导出。

以上就是数据库编程,数据库编程在实际过程只比命令行语句应用的更多,更频繁,使用命令行语句并不是最常见的。

一个是跟编程相结合,另外一个是雏形化工具,数据库要快速实行可视化浏览就要使用这个工具。

SQLite 数据库是轻量级的,不仅可以在大型服务器端部署,最关键是可以很容易部署到边缘计算设备中,甚至是一个中端设备中;代码是可见的,移植成本为零,整个源码都给到用户,用户根据自己需求进行编译即可。

相关文章
|
7天前
|
存储 关系型数据库 MySQL
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
53 5
|
6天前
|
存储 API 数据库
QML使用Sqlite数据库存储ListModel数据
本文介绍了在QML中使用Sqlite数据库存储ListModel数据的方法,包括如何创建数据库、读取数据、动态添加和删除数据,以及如何在程序启动和退出时与数据库同步数据。
|
6天前
|
数据库 数据库管理
qt对sqlite数据库多线程的操作
本文总结了在Qt中进行SQLite数据库多线程操作时应注意的四个关键问题,包括数据库驱动加载、加锁、数据库的打开与关闭,以及QsqlQuery变量的使用。
|
8天前
|
SQL 关系型数据库 MySQL
php学习笔记-连接操作mysq数据库(基础)-day08
本文介绍了PHP中连接操作MySQL数据库的常用函数,包括连接服务器、设置字符集、关闭连接、选择数据库、结果集释放、获取影响行数以及遍历结果集等操作。通过书籍查询的实例演示了如何使用这些函数进行数据库操作,并提供了一个PHP操纵MySQL数据库的模板。
php学习笔记-连接操作mysq数据库(基础)-day08
|
8天前
|
SQL 数据库 数据库管理
SQLite 创建数据库
SQLite 的 sqlite3 命令被用来创建新的 SQLite 数据库。您不需要任何特殊的权限即可创建一个数据。
13 0
|
10天前
|
JSON NoSQL 数据库
和SQLite数据库对应的NoSQL数据库:TinyDB的详细使用(python3经典编程案例)
该文章详细介绍了TinyDB这一轻量级NoSQL数据库的使用方法,包括如何在Python3环境中安装、创建数据库、插入数据、查询、更新以及删除记录等操作,并提供了多个编程案例。
23 0
|
2月前
|
SQL 存储 小程序
【教程】navicat配合HTTP通道远程连接SQLite数据库
本文介绍了如何通过 Navicat Premium 工具配合 n_tunnel_sqlite.php 和 HTTP 通道远程连接服务器上的 SQLite 数据库。SQLite 是一种自给自足的、无服务器的 SQL 数据库引擎,由于其端口未对外开放,直接使用 Navicat 进行远程连接不可行。文章详细记录了使用 HTTP 通道实现远程连接的过程,包括定位本地 `ntunnel_sqlite.php` 文件,将其上传至服务器,并通过 Navicat 配置 HTTP 通道连接 SQLite 数据库的具体步骤。
52 0
【教程】navicat配合HTTP通道远程连接SQLite数据库
|
2月前
|
开发工具 数据安全/隐私保护 索引
LDAP学习笔记之二:389-DS(RHDS) 增删改查基本操作
LDAP学习笔记之二:389-DS(RHDS) 增删改查基本操作
|
18天前
|
NoSQL 关系型数据库 MySQL
微服务架构下的数据库选择:MySQL、PostgreSQL 还是 NoSQL?
在微服务架构中,数据库的选择至关重要。不同类型的数据库适用于不同的需求和场景。在本文章中,我们将深入探讨传统的关系型数据库(如 MySQL 和 PostgreSQL)与现代 NoSQL 数据库的优劣势,并分析在微服务架构下的最佳实践。
|
20天前
|
存储 SQL 关系型数据库
使用MySQL Workbench进行数据库备份
【9月更文挑战第13天】以下是使用MySQL Workbench进行数据库备份的步骤:启动软件后,通过“Database”菜单中的“管理连接”选项配置并选择要备份的数据库。随后,选择“数据导出”,确认导出的数据库及格式(推荐SQL格式),设置存储路径,点击“开始导出”。完成后,可在指定路径找到备份文件,建议定期备份并存储于安全位置。
160 11
下一篇
无影云桌面