嵌入式设备中可以使用SQLite3吗?

news2025/1/23 4:38:27

摘要:数据库是用来存储和管理数据的专用软件,使得管理数据更加安全,方便和高效。数据库对数据的管理的基本单位是表(table),在嵌入式linux中有时候它也需要用到数据库,听起来好难,其实就是几个函数,掌握了就好。

一、常见的数据库

大型数据库(大型机)Oracle(亿级),中型数据库(分布式超大型)mysql(百万级),轻型数据库(嵌入式设备)sqlite(万级),访问数据库使用SQL语句,适用于所有的数据库。

二、安装SQLite3

有C环境就可以调用sqlite

2.1直接用命令安装

sudo apt-get update
sudo apt-get install sqlite3

2.2 直接编译源码

将源码拷贝到Ubuntu的非共享目录解压

解压命令:

tar zvxf sqlite-autoconf-3380500.tar.gz

配置

cd sqlite-snapshot-201708031550
./configure --prefix=/home/gec/sqlite

编译

make        

安装

make install         

三、SQLite的使用

新建数据库文件
sqlite3 数据库文件的路径   //打开/创建
//比如:sqlite3 first.db

3.1 基本操作命令

.exit/.quit -------- 退出数据库命令行
.help -------------- 帮助说明信息
.tables ------------ 查看当前数据库中所有的表

3.2 数据库访问的SQL语句

基本语法:

所有的SQL语句都以分号(;)结束
不区分大小写

3.3 新建表格

create table 表名(字段名1 字段类型1,字段名2 字段类型2,字段名3 字段类型3,...);
比如:
//创建一个stutbl的表,表中有3个字段
//分别是整数类型的学号id,字符串类型的name和整数类型的age
create table zhiguoxin(id int,name char[20],age int);
//不存在则创建
create table if not exists zhiguoxin(id int,name char[20],age int);
//如果希望表中某个字段的内容不重复,可以用unique修饰该字段
create table if not exists zhiguoxin(id int unique,name char[20],age int);

3.4 删除表格

drop table 表名;
//drop table zhiguoxin;

3.5 往表格中插入数据

insert into 表名 values(字段值1,字段值2,字段值3,....);
//字段值如果是字符串,必须用''(单引号)括起来
比如:
insert into zhiguoxin values(1001,'刘尧',18);
insert into zhiguoxin values(1002,'聂衍文',19);
insert into zhiguoxin values(1003,'杨佳晨',20);
insert into zhiguoxin values(1004,'冯华阳',21);

完成插入之后,zhiguoxin 的表格内容如下:

idnameage
1001刘尧18
1002聂衍文19
1003杨佳晨20
1004冯华阳21

3.6 查询表中的数据

//查询表中的所有数据

select * from 表名;
//select * from zhiguoxin;

3.7 查看数据库

可以把first.db数据库文件拷贝至windows下,使用SQLite Developer打开即可看到。SQLite Developer下载地址

https://mydown.yesky.com/pcsoft/443425.html

3.8 按条件查找

1.使用where指定查询条件

select * from zhiguoxin where id=1003;//查询id值为1003的条目
select * from zhiguoxin where age>=19 and age<21;
select * from zhiguoxin where age>=19 or age<21;

2.指定查询的字段

select id,name,age from zhiguoxin;//只查询id,name,age的字段 

3.使用where+like实现模糊查询

select * from zhiguoxin where name like '刘%';//查找名字以刘开头的条目

4.使用order by实现查询结果按某个字段的值升序/降序输出

select * from zhiguoxin order by age desc;//按年龄降序排序     
select * from zhiguoxin order by id asc;  //按id升序排序   

3.9 删除表中的条目

delete from 表名 where 条件;//删除所有符合条件的条目
比如:
delete from zhiguoxin where id=1001;

3.10 更新(修改)表中的条目

update 表名 set 字段名1=字段值1,字段名2=字段值2... where 条件;//修改符合条件的条目
比如:
update zhiguoxin set age=100 where id=1002;

3.11 SQLite中字段类型

数字:

int ------- 整型
smallint ---- 短整型
tinyint ----- 微型整数(0~255)
bit --------- 0 or 1
float ------ 单精度浮点型
real ------- 双精度浮点型

字符串:

char ---------- 非unicode定长字符串 < 8000
varchar ------- 非unicode变长字符串 < 8000
text ---------- 非unicode变长字符串 < 2^32-1
nchar ---------- unicode定长字符串 < 8000
nvarchar ------- unicode变长字符串 < 8000
ntext ---------- unicode变长字符串 < 2^32-1

四、SQLite的C语言访问接口

sqlite本身自带C语言访问接口,在C语言的环境下可以直接使用,使用这些接口的代码需要 sqlite的源码编译进可执行程序 或者 编译时链接sqlite的库。

4.1 打开 sqlite3_open

int sqlite3_open(
  const char *filename,   /* 数据库的文件路径 */
  sqlite3 **ppDb          /* 输出参数:传出代表打开数据库的句柄 */
);
//成功返回SQLITE_OK,否则打开失败char ---------- 非unicode定长字符串 < 8000
varchar :非unicode变长字符串 < 8000
text :非unicode变长字符串 < 2^32-1
nchar:unicode定长字符串 < 8000
nvarchar : unicode变长字符串 < 8000
ntext :unicode变长字符串 < 2^32-1

4.2 关闭 sqlite3_close

int sqlite3_close(sqlite3 *pDb);
//传入要关闭的数据库的句柄

4.3 编译方法

1.直接编译源码
gcc sqlite3.c sqlite_test.c -pthread -ldl -o sqlite_test
2.链接sqlite3的动态库
gcc sqlite_test.c -pthread -ldl -lsqlite3 -L /home/gec/sqlite/lib -o sqlite_test  
//如果运行时找不到sqlite3的库,可以将编译出来的库文件拷贝到/usr/lib目录下(cp -r)      

4.4 执行SQL语句的接口 sqlite3_exec

int sqlite3_exec(
  sqlite3 *pDb,                              /* 打开的数据库的句柄 */
  const char *sql,                           /* 要执行的SQL语句 */
  int (*callback)(void *arg,int col,char **str,char **name),  
  /* 回调函数,处理SQL语句执行返回的结果(查询),一条结果调用一次 
      arg - exec的第四个参数
      col - 本条结果的字段数
      str - 记录字段值的数组
      name - 记录字段名的数组
     回调函数必须返回SQLITE_OK */
  void *arg,                                 /* 传递给回调函数的第一个参数 */
  char **errmsg                              /* 错误信息 */
);
//成功返回SQLITE_OK,否则执行失败

几个例子

//连接数据库
int Connection_Sqlite3DataBase()
{
    rc = sqlite3_open("./face_database/face.db", &db);
    if (rc != SQLITE_OK)
    {
        fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
        sqlite3_close(db);
        exit(1);
    }
    else
        printf("You have opened a sqlite3 database named bind.db successfully!\nCongratulation! Have fun!\n");
    return 0;
}
//将图片插入到数据库
void insert_face_data_toDataBase(const char *name, MByte *face_feature, MInt32 featureSize)
{
    sqlite3_prepare(db, "insert into face_data_table(name,face_feature,feature_size) values (?,?,?);", -1, &stmt, NULL);
    sqlite3_bind_text(stmt, 1, name, strlen(name), NULL);
    sqlite3_bind_blob(stmt, 2, face_feature, featureSize, NULL);
    sqlite3_bind_int(stmt, 3, featureSize);
    sqlite3_step(stmt);
}

                                                        end

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

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

相关文章

论文精读:Realtime Multi-Person 2D Pose Estimation using Part Affinity Fields ∗

姿态估计openpose系列算法解读 姿态估计任务 姿态估计任务首先需要检测出人体的各个关键点,将人体关键点进行拼接。 任务的困难有,首先,对于关键点检测任务,需要处理遮挡的问题,在拼接的过程中,需要处理多人的情况,即不能将不同人的关键点进行拼接。 标注数据信息 COCO…

linux系统中利用QT实现音乐播放器的功能

大家好&#xff0c;今天主要和大家聊一聊&#xff0c;如何使用QT中的音乐播放器的功能与方法。 目录 第一&#xff1a;音乐播放器基本简介 第二&#xff1a;应用具体代码实现 第三&#xff1a;在源代码mainwindow.cpp中的实现 第四&#xff1a;程序运行效果 第一&#xff…

1.1计算机工作过程(超详细)

文章目录一、计算机组成框图二、思维导图三、部件剖析&#xff08;1&#xff09;存储器&#xff08;2&#xff09;运算器&#xff08;3&#xff09;控制器四、案例剖析&#xff08;重点&#xff09;&#xff08;1&#xff09;a2&#xff08;2&#xff09;a*b&#xff08;3&…

关于 国产麒麟系统上长时间运行Qt程序.xsession-erros文件占满磁盘导致无法写入 的解决方法

若该文为原创文章&#xff0c;转载请注明原文出处 本文章博客地址&#xff1a;https://hpzwl.blog.csdn.net/article/details/128660728 红胖子(红模仿)的博文大全&#xff1a;开发技术集合&#xff08;包含Qt实用技术、树莓派、三维、OpenCV、OpenGL、ffmpeg、OSG、单片机、软…

[强网杯 2019]随便注

目录 信息收集 方法一&#xff1a;堆叠注入 方法二&#xff1a;MySQL预处理 语法 payload 方法三&#xff1a;handler 知识点 语法 payload 信息收集 1 You have an error in your SQL syntax; check the manual that corresponds to your MariaDB server version f…

开发中常用的Spring注解

一.IOC容器 Configuration ConpoentScan CompoentScans Bean Import DependsOn Lazy Compoent Repository Service Controller Autowired Qualifier 二.AOP切面 Aspect Pointcut Before After AfterReturning AfterThrowing Around 三.事务声明 Transac…

nacos一:服务注册

为什么用nacos: Eureka需要自己搭建项目&#xff0c;nacos下载后&#xff0c;就可以直接访问web界面,自带负载均衡 Nacos可以 1替代eureka做服务注册中心 2替代Config做服务配置中心 使用 一&#xff1a; 1 下载nacos,在bin目录下打开cmd窗口&#xff0c;输入startup.cmd -m s…

100 亿美元!微软豪赌 AI,OpenAI 渗透 GitHub、Office、Bing

OpenAI 这把 ChatGPT 的火还在持续地燃烧&#xff01;作者 | 唐小引出品 | CSDN&#xff08;ID&#xff1a;CSDNnews&#xff09;今天&#xff0c;据路透社援引 Semafor 消息报道&#xff0c;微软正在计划向 OpenAI 再次投资 100 亿美元&#xff0c;如果合作达成&#xff0c;微…

【STM32学习】SysTick定时器(嘀嗒定时器)

SysTick定时器一、参考资料二、时钟源选择与定时时间计算1、时钟源选择2、定时时间计算三、SysTick_Handler中断服务函数一、参考资料 嘀嗒定时器&#xff1a;时钟源、寄存器 二、时钟源选择与定时时间计算 结合正点原子的代码进行说明&#xff1a; 1、时钟源选择 从上图可以发…

通讯录的实现(详解)(后附完整源代码)

通讯录的实现一.所需要的功能二.大致菜单三.创建通讯录四.增加联系人五.显示联系人六.查找联系人七.删除联系人八.修改联系人一.所需要的功能 对于通讯录来说&#xff0c;我们需要它实现以下几个功能。 1.人的信息&#xff1a;姓名年龄性别电话地址。 2.可以存放100个人的信息…

VMware Workstation Pro 16安装Windows 11

1&#xff1a;首先在机器中安装VMware Workstation Pro。 2&#xff1a;准备Windows 11的安装镜像。 3&#xff1a;安装Windows 11的系统要求&#xff0c;这个很关键不满足条件无法安装&#xff0c;其中我们只需要注意系统固件和TPM这两项就行。 4&#xff1a;运行VMware Wor…

使用SQL4Automation让CodeSYS连接数据库

使用SQL4Automation让CodeSYS连接数据库 摘要&#xff1a;本文旨在说明面向CodeSYS的数据库连接方案SQL4Automation的使用方法。 1.SQL4Automation简介 1.1.什么是SQL4Automation SQL4Automation是一套工业用途的软件解决方案&#xff0c;它主要的功能就是为PLC和机器人控制提…

王道操作系统笔记(一)———— 计算机系统概述

文章目录一、操作系统基本概念1.1 基本概念1.2 四大特征1.3 目标和功能二、操作系统的分类与发展三、操作系统的运行环境3.1 运行机制3.2 中断和异常3.3 系统调用四、操作系统的体系结构4.1 宏内核与微内核4.2 分层结构4.3 模块化4.4 外核五、操作系统引导六、虚拟机一、操作系…

nacos2.x集群版搭建

1. 预备环境准备 请确保是在环境中安装使用: 64 bit OS Linux/Unix/Mac&#xff0c;推荐使用Linux系统。--这里使用linux系统64 bit JDK 1.8&#xff1b;下载. 配置。Maven 3.2.x&#xff1b;下载. 配置。3个或3个以上Nacos节点才能构成集群。官网地址:集群部署说明 2、服务器…

Android 深入系统完全讲解(12)

11 跟踪一个服务&#xff0c;直接找到驱动实现 如果说我自己学习整个系统&#xff0c;直到底层驱动的方法&#xff0c;我想说的就是我常用的就是跟踪震动这个模块&#xff0c;而为什么是这个&#xff0c;主要是简单&#xff0c;但是又是从上到下都具备&#xff0c;对于学习系统…

【OpenCV】拾遗

前言 本篇博客主要是总结OpenCV使用过程中遇到的一些问题&#xff0c;便于以后参考。 以下所有内容均基于VS2015 OpenCV_v4.5.1 及 VS Code MinGW_v4.3.5 CMake_v3.20.0 OpenCV_v4.5.1&#xff0c;前者的配置教程可以参考这个链接&#xff0c;后者的配置教程可以参考这个链…

2022年衣物清洁行业市场报告:洗衣液等四大高增长类目分析

随着人们经济水平的提高以及消费观念的升级&#xff0c;当前个护家清用品逐渐朝品质化、精细化、个性化的方向发展&#xff0c;类目衍生更替更频繁、迭代速度更快。 得益于庞大的人口规模&#xff0c;个护家清产品规模巨大&#xff0c;衣物清洁行业虽增速放缓但仍在个护家清行…

OpenFoam收缩扩张喷管(拉瓦尔喷管)边界条件的设置

简介 收缩扩张喷管&#xff08;也成拉瓦尔喷管&#xff09;广泛应用于火箭推进。将其流动特性定性描述如下&#xff1a; &#xff08;1&#xff09;当入口流量较小时&#xff0c;不出现雍塞&#xff0c;流速先增大后减小&#xff0c;全程为亚声速。出口压力即为大气压&#x…

金融数学建模——2022年大湾区杯金融数学建模B题(解题思路及部分python代码)

目录 一、概述 二、赛题及解读 1.赛题详情 2.赛题解读 三、解题方法 1.第一问 第一问部分代码 2.第二问 第二问部分代码 3.第三问&#xff1a; 第三问部分代码 4.第四问 三、总结 一、概述 这次比赛是我们队伍第一次参加金融数学建模&#xff0c;尽管在比赛前用2020年…

数据结构与算法4—队列

队列 队列的定义 队列(Queue)也是一种运算受限的线性表。它只允许在表的一端进行插入&#xff0c;而在另一端进行删除。允许删除的一端称为队头(front)&#xff0c;允许插入的一端称为队尾(rear)。队列的修改是依先进先出的原则进行的。队列的基本操作 1&#xff0e;初始化队…