【六】嵌入式SQLite数据库
文章目录
1.简介
轻量化,易用的嵌入式数据库,用于设备端的数据管理,可以理解成单点的数据库。传统服务器型数据库用于管理多端设备,更加复杂
SQLite是一个无服务器的数据库,是自包含的。这也称为嵌入式数据库,这意味着数据库引擎作为应用程序的一部分运行。
MySQL需要运行服务器,MySQL将需要客户端和服务器架构通过网络进行交互。
| SQLite的优点 | SQLite的缺点 | MySQL的优点 | MySQL的缺点 |
|---|---|---|---|
| 基于文件,易于设置和使用 适合基础开发和测试 轻松携带 使用标准SQL语法进 行微小更改 使用方便 |
缺乏用户管理和安全功能 不容易扩展 不适合大数据库 无法定制 |
使用方便 提供了许多与数据库相关的功能 良好的安全功能 易于扩展,适用于大型数据库 提供良好的速度和性能 提供良好的用户管理和多种访问控制 |
需要一些技术专业知识来设置 与传统SQL相比,语法略有不同 |
基于嵌入式的数据库主要有:SQLite,Firebird,Berkeley DB,eXtremeDB
- Firebird 是关系型数据库,功能强大,支持存储过程,SQL兼容等
- SQLite 关系型数据库,体积小,支持ACID事务
- Berkeley DB 并没有数据库服务器的概念,他的程序直接链接到应用程序中
- eXtremeDB 是内存数据库,运行效率高
2.SQLite数据库安装
安装方式一:
这个安装的版本是2
sudo apt-get -y install sqlite
安装方式二:
总括:
- 把下载的文件
sqlite-autoconf-3450300.tar.gz上传到开发板 - 解压:
tar xvf sqlite-autoconf-3450300.tar.gz cd sqlite-autoconf-3450300进入文件夹./configure --prefix=/usr/local配置安装路径在/usr/localmake编译(比较久10分钟)sudo make install安装
详细过程
1.下载网址:
https://www.sqlite.org/download.html
下载sqlite3软件包(每一阶段的版本会不一样,一直在更新)

2.将下载好的压缩包上传到开发板

3.解压:tar xvf sqlite-autoconf-3450300.tar.gz

4.开始配置编译
cd sqlite-autoconf-3450300 //进入文件夹
./configure --prefix=/usr/local //配置安装路径在/usr/local
make //开始编译,时间很久,10分钟左右
sudo make install//安装
在主页面打入sqlite3进入数据库


3.SQLite命令用法
里面的很多命令背会就行,会用会改,没有什么道理可言。
这里只讲最基础的用法,详细的可以看https://www.runoob.com/sqlite/sqlite-tutorial.html
在正式开始之前建议先建一个名为sqlite的文件夹,方便后续的项目管理
mkdir sqlite //创建名为sqlite的文件夹
cd sqlite //进入名为sqlite的文件夹
1.创建数据库
一个数据库可以创建多个表格,每个表格又可以创建多个数据

刚进入数据库就会给我们提示创建数据库的方法
热知识:
.db 文件通常是指 SQLite 数据库文件。SQLite 是一种轻量级的数据库引擎,常用于移动应用程序和小型桌面应用程序中存储数据。这些文件包含了结构化的数据,可以通过 SQLite 数据库管理工具或编程语言中的 SQLite 库进行访问和操作。
创建方式一:进入数据库后创建
sqlite3 //进入数据库
.open test.db //创建名为test.db 的数据库(有的话直接打开,没有直接创建)
.quit //退出
数据库退出后在命令当前路径创建数据库test.db

创建方式二:在进入数据库时直接创建
sqlite3 test.db //在命令运行当前窗口创建数据库test.db
//在数据库命令下
.databases 列出当前打开的数据库
.quit 退出

2.创建和查看表格
思考一下我们以前的结构体,其实就很像一个列表。
不过在sqlite数据库里面,int=Inteager
struct stu{
int id;
char name;
int score;
}
2.1在sqlite数据库下的操作:
2.1.1创建表格:
//创建一个名为stu1 的表格
create table stu1(id Integer,name char,score Integer);
create table stu(id Integer,name char,score Integer);
2.1.2查看有哪些表格:
.tables

3.插入查看数据(记录)
以下命令均在数据库命令行中操作
3.1插入数据:
insert into stu values(18130106,'huang',99);// 必须是单引号'',高版本的sqlite3已经不支持双引号""
insert into stu values(22222226,'ming',59);
insert into stu2(name,score) values('huanggang',98); //插入部分字段内容
3.2查看数据
select * from stu; //查询stu所有字段的结果
select name,score from stu; //查询stu数据库中部分字段的内容

4.删除更改数据(记录)
以下命令均在数据库命令行中操作
4.1删除表
drop table stu;
4.2删除一条数据
delete from stu where id = 18130101;
4.3更改一条数据
// 要改的表 改什么 匹配的信息
update stu set name = 'huangg' where id = 18130106;
4.4增加一列
alter table stu add column sex char;
4.SQLite编程操作
注意:文中所讲版本为sqlite3,版本过低的请自行更新。
1.打开/创建数据库的C接口
下面的 C 代码段显示了如何连接到一个现有的数据库。
如果数据库不存在,那么它就会被创建,最后将返回一个数据库对象。
用到的函数介绍:
1.1 sqlite3_open:打开一个数据库对象;
//1.头文件
#include <sqlite3.h>
//2.函数原型
int sqlite3_open(const char *filename, sqlite3 **ppDb);
filename:要打开的sqlite3数据库的路径名
ppDb: 二级指针,用来保存打开的数据库的连接对象。
//3.返回值
成功返回SQLITE_OK,失败返回其他值。
返回值所对应的宏:

1.2 sqlite3_close:关闭数据库连接对象
//1.头文件
#include <sqlite3.h>
//2.函数原型
int sqlite3_close(sqlite3*);
在使用此函数之前要先调用 sqlite3_open(); 打开的数据库连接。
//3.返回值
所有与连接相关的语句都应在连接关闭之前完成。
如果还有查询没有完成,将返回SQLITE_BUSY 禁止关闭的错误消息。
1.3用于查看错误代码信息:
const char *sqlite3_errmsg(sqlite3*);
1.4常用来获取最近调用的API接口返回的错误代码(是错误代码数字)
sqlite3_errcode(sqlite3*) ;
代码示例:
编译:gcc a.c -lsqlite3 链接到库
运行:./a.out test.db 链接到已有的数据库(如果没有会创建一个)
//a.c
#include <stdio.h>
#include <sqlite3.h>
#include <stdlib.h>
int main(int argc,char **argv)
{
sqlite3 *db = NULL;
int ret = 0;
if(argc<2){
printf("Uage: %s xxx.db\n",argv[0]);
exit(-1);
}
if((ret = sqlite3_open(argv[1],&db)) == SQLITE_OK){
//打开或创建一个数据库对象 成功返回SQLITE_OK 0
printf("ret = %d create %s ok\n",ret,argv[1]);//打印返回的数值
}else{
printf("ret = %d creat %s fail\n",ret,argv[1]);//打印返回错误码的数值
printf("error num = %d error mesg:%s\n",sqlite3_errcode(db),sqlite3_errmsg(db));//获取最近调用的API接口返回的错误代码 and 错误信息输出
if(ret==14){
//错误码判断
printf("permisson deny\n");

嵌入式SQLite数据库&spm=1001.2101.3001.5002&articleId=140882084&d=1&t=3&u=e9ca7b844a2142ce9f7374a9d9936fbe)
1902

被折叠的 条评论
为什么被折叠?



