ARM下的sqlite3交叉编译实例

ARM下的sqlite3交叉编译实例

本文将详细介绍sqlite3如何在ARM开发中配置交叉编译环境以及移植到ARM开发板中对其进行实际操作!


前言

sqlite3简介

SQLite是一个软件库,实现了自给自足的、无服务器的、零配置的、事务性的 SQL 数据库引擎。SQLite是一个增长最快的数据库引擎,这是在普及方面的增长,与它的尺寸大小无关。SQLite 源代码不受版权限制。

什么是 SQLite?

SQLite是一个进程内的库,实现了自给自足的、无服务器的、零配置的、事务性的 SQL 数据库引擎。它是一个零配置的数据库,这意味着与其他数据库不一样,您不需要在系统中配置。就像其他数据库,SQLite 引擎不是一个独立的进程,可以按应用程序需求进行静态或动态连接。SQLite 直接访问其存储文件。

为什么要用 SQLite?

  • 不需要一个单独的服务器进程或操作的系统(无服务器的)。
  • SQLite 不需要配置,这意味着不需要安装或管理
  • 一个完整的 SQLite 数据库是存储在一个单一的跨平台的磁盘文件。
  • SQLite 是非常小的,是轻量级的,完全配置时小于 400KiB,省略可选功能配置时小于250KiB。
  • SQLite 是自给自足的,这意味着不需要任何外部的依赖。
  • SQLite 事务是完全兼容 ACID 的,允许从多个进程或线程安全访问。。

一、下载sqlite3源码包

sqlite3官方下载地址
这里我下载的是3.34.0版本

二、解压压缩包

	tar -zxvf sqlite-autoconf-3340000.tar.gz

生成makefile

./configure CC=arm-linux-gnueabihf-gcc --host=arm-linux --prefix=/opt/sqlite3

说明:./configure生成makefile(1)CC:arm平台所使用的交叉编译工具,(2)–host:指定运行环境为arm-linux (3)prefix:指定安装目录

接着执行以下三命令:

	make clean
	make
	make install

三、编写测试文件

#include <stdio.h>
#include "sqlite3.h"

int main(int argc, char* argv[])
{
   sqlite3 *db;
   char *zErrMsg = 0;
   int rc;

   rc = sqlite3_open("test.db", &db);

   if( rc ){
      fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));

   }else{
      fprintf(stderr, "Opened database successfully\n");
   }
   sqlite3_close(db);
}

四、编译目标文件

arm-linux-gcc sqlitetest.c -o sqltest -I/opt/sqlite3/include -L/opt/sqlite3/lib -lsqlite3
root@ubuntu:/home/jwx/work/033N1# ls -l
total 32
-rwxr-xr-x 1 root root 7377 Sep  4 20:37 a.out
-rw-r--r-- 1 root root  353 Sep  4 20:47 sqlitetest.c
-rw-r--r-- 1 root root  361 Sep  4 20:36 sqlitetest.c~
-rwxr-xr-x 1 root root 6068 Sep  5 20:19 sqltest
-rw-r--r-- 1 root root    0 Sep  4 20:37 test.db
root@ubuntu:/home/jwx/work/033N1# ./sqltest
bash: ./sqltest: cannot execute binary file

五、运行测试用例

需要将/opt/sqlite3/lib拷贝到/lib下(或者加入到环境变量/etc/profile中),/opt/sqlite3/bin拷贝到/bin

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值