将sqlite3移植到arm开发板上:

一、下载源代码

sqlite3网址:https://www.sqlite.org/download.html

下载:sqlite-autoconf-3460100.tar.gz

二、解压

在Linux家目录下创建一个sqlite3文件夹,将压缩包复制到该文件夹下,再在该目录下打开一个终端,执行命令解压文件:

bash 复制代码
tar -vxf sqlite-autoconf-3460100.tar.gz

三、编译

1、再在sqlite3目录下再创建一个install文件夹

2、进入sqlite-autoconf-3460100目录:

bash 复制代码
cd sqlite-autoconf-3460100

3、 配置 SQLite:

bash 复制代码
./configure --host=arm-linux --prefix=/home/linux/sqlite3/install

这个命令的目的是为了在当前系统上配置 SQLite,以便进行交叉编译,生成可以在 ARM 架构的 Linux 系统上运行的 SQLite 版本,并将其安装到指定的目录中。

  1. ./configure:这是许多开源软件中用于进行配置的脚本。它会检查系统环境、依赖关系,并根据给定的选项生成相应的 Makefile 和其他配置文件

  2. --host=arm-linux

    • --host选项指定了目标平台。在这里,arm-linux表示目标是 ARM 架构的 Linux 系统。这告诉配置脚本在编译过程中生成适用于 ARM 架构的代码。
  3. --prefix=/home/linux/sqlite3/install

    • --prefix选项指定了安装目录的前缀。当编译完成后,软件将被安装到这个指定的目录下。在这个例子中,软件将被安装到/home/linux/sqlite3/install目录。这个目录通常包含了可执行文件、库文件、头文件等。

4、编译

分别执行make、make install

make时会执行Makefile命令

make install 会将编译生成的文件放在prefix所到指定的/home/linux/sqlite3/install 目录下,其实就是拷贝过去。

make编译时会比较慢,需要一些时间等待,直到命令提示符跳出

四、移植

这里使用的挂载目录是/home/linux/nfs

步骤:

1.查看prefix指定的目录/home/linux/sqlite3/install下是否出现了bin,include,lib目录,有的话代表成功。
2.打开bin目录,将sqlite3拷贝到nfs目录下。
3.将lib目录下的libsqlite3.so libsqlite3.so.0.8.6 libsqlite3.so.0 文件拷贝到nfs目录下。

五、连接开发板,执行挂载命令

bash 复制代码
mount -o nolock,tcp 192.168.1.17:/home/linux/nfs /mnt

注意:执行挂载命令时加上tcp,是因为NFS的默认传输协议是 UDP,而PC机与嵌入式系统通过UDP交互时就会出现严重的网卡丢包现象,所以需要手动改为TCP协议。

进入开发板下的mnt目录

将sqlite3复制到开发板家目录下的bin目录

将libsqlite3.so libsqlite3.so.0.8.6 libsqlite3.so.0复制到开发板家目录下的lib目录

五、运行sqlite3

在开发板命令行输入sqlite,回车,出现以下信息表示移植成功

六、测试

编写一个执行sql语句的程序:

cpp 复制代码
#include <stdio.h>
#include <sqlite3.h>
int main()
{
    sqlite3* db;
    int ret = sqlite3_open("/my/user.db",&db);
    if ( ret != SQLITE_OK )
    {
        fprintf(stderr,"sqlite3_open error,%s\n",sqlite3_errstr(ret));
        sqlite3_close(db);
        return 1;
    }

    char *errmsg;
    char sqlite3_cmd[] = "insert into my_table values(NULL,'lao6');";
    ret = sqlite3_exec(db,sqlite3_cmd,NULL,NULL,&errmsg);
    if ( ret != SQLITE_OK )
    {
        fprintf(stderr,"exec error,%s\n",errmsg);
        sqlite3_free(errmsg);
        sqlite3_close(db);
        return 1;
    }

    sqlite3_close(db);

    printf("Hello World!\n");
    return 0;
}

交叉编译该程序:

编译时要指定头文件和库的路径

复制代码
arm-linux-gcc main.c -lsqlite3 -I /home/linux/sqlite3/install/include -L /home/linux/sqlite3/install/lib

将生成的a.out复制到nfs,在板子上运行该程序,打开数据库查看运行结果。

相关推荐
睡觉的时候不会困5 小时前
Redis 主从复制详解:原理、配置与主从切换实战
数据库·redis·bootstrap
程序员的世界你不懂7 小时前
【Flask】测试平台开发,新增说明书编写和展示功能 第二十三篇
java·前端·数据库
自学也学好编程7 小时前
【数据库】Redis详解:内存数据库与缓存之王
数据库·redis
JAVA不会写7 小时前
在Mybatis plus中如何使用自定义Sql
数据库·sql
IT 小阿姨(数据库)7 小时前
PgSQL监控死元组和自动清理状态的SQL语句执行报错ERROR: division by zero原因分析和解决方法
linux·运维·数据库·sql·postgresql·centos
ChinaRainbowSea8 小时前
7. LangChain4j + 记忆缓存详细说明
java·数据库·redis·后端·缓存·langchain·ai编程
小马学嵌入式~9 小时前
嵌入式 SQLite 数据库开发笔记
linux·c语言·数据库·笔记·sql·学习·sqlite
Java小白程序员9 小时前
MyBatis基础到高级实践:全方位指南(中)
数据库·mybatis
Monly219 小时前
人大金仓:merge sql error, dbType null, druid-1.2.20
数据库·sql
不宕机的小马达9 小时前
【Mysql|第一篇】Mysql的安装与卸载、Navicat工具的使用
数据库·mysql