将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,在板子上运行该程序,打开数据库查看运行结果。

相关推荐
NineData5 小时前
NineData 迁移评估功能正式上线
数据库·dba
NineData11 小时前
数据库迁移总踩坑?用 NineData 迁移评估,提前识别所有兼容性风险
数据库·程序员·云计算
赵渝强老师13 小时前
【赵渝强老师】PostgreSQL中表的碎片
数据库·postgresql
全栈老石17 小时前
拆解低代码引擎核心:元数据驱动的"万能表"架构
数据库·低代码
倔强的石头_1 天前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
jiayou643 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
李广坤4 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
爱可生开源社区5 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1775 天前
《从零搭建NestJS项目》
数据库·typescript
加号35 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql