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

相关文章
|
8月前
|
安全 Java 数据库
Jasypt加密数据库配置信息
本文介绍了使用 Jasypt 对配置文件中的公网数据库认证信息进行加密的方法,以提升系统安全性。主要内容包括:1. 背景介绍;2. 前期准备,如依赖导入及版本选择;3. 生成密钥并实现加解密测试;4. 在配置文件中应用加密后的密码,并通过测试接口验证解密结果。确保密码安全的同时,保障系统的正常运行。
545 3
Jasypt加密数据库配置信息
|
存储 数据库 数据库管理
SQLite中的B-Tree实现细节分析
SQLite在存储在外部的数据库是以B-Tree来组织的。
338 8
|
存储 关系型数据库 MySQL
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
5012 2
|
消息中间件 数据采集 数据库
小说爬虫-03 爬取章节的详细内容并保存 将章节URL推送至RabbitMQ Scrapy消费MQ 对数据进行爬取后写入SQLite
小说爬虫-03 爬取章节的详细内容并保存 将章节URL推送至RabbitMQ Scrapy消费MQ 对数据进行爬取后写入SQLite
248 1
|
安全 算法 Java
数据库信息/密码加盐加密 —— Java代码手写+集成两种方式,手把手教学!保证能用!
本文提供了在数据库中对密码等敏感信息进行加盐加密的详细教程,包括手写MD5加密算法和使用Spring Security的BCryptPasswordEncoder进行加密,并强调了使用BCryptPasswordEncoder时需要注意的Spring Security配置问题。
1260 0
数据库信息/密码加盐加密 —— Java代码手写+集成两种方式,手把手教学!保证能用!
|
存储 关系型数据库 MySQL
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
1045 5
|
存储 API 数据库
QML使用Sqlite数据库存储ListModel数据
本文介绍了在QML中使用Sqlite数据库存储ListModel数据的方法,包括如何创建数据库、读取数据、动态添加和删除数据,以及如何在程序启动和退出时与数据库同步数据。
451 2
|
JSON NoSQL 数据库
和SQLite数据库对应的NoSQL数据库:TinyDB的详细使用(python3经典编程案例)
该文章详细介绍了TinyDB这一轻量级NoSQL数据库的使用方法,包括如何在Python3环境中安装、创建数据库、插入数据、查询、更新以及删除记录等操作,并提供了多个编程案例。
959 0
|
存储 安全 关系型数据库
"揭秘!如何设计数据库架构,让信息系统心脏强健无比?一场关于数据效率、安全与可扩展性的深度探索"
【8月更文挑战第19天】数据库架构是信息系统的核心,关乎数据存储效率与安全及应用性能和扩展性。优秀设计需综合考量业务需求、数据模型选择、查询优化、事务处理、安全性和扩展性。首先,深刻理解业务需求,如电商系统需高效处理并增长商品、订单等数据。其次,基于需求选择合适的数据模型,如关系型或非关系型数据库。再者,优化查询性能与索引策略以平衡读写负载。同时,考虑事务处理和并发控制以保证数据一致性和完整性。最后,加强安全性措施和备份恢复策略以防数据风险。通过这些步骤,可以构建稳健高效的数据库架构,支持系统的稳定运行。
226 0
|
5月前
|
缓存 关系型数据库 BI
使用MYSQL Report分析数据库性能(下)
使用MYSQL Report分析数据库性能
434 158