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