Android sqlite3 编译及安装

  1. 编译 sqlite3
    去官网下载 sqlite-autoconf-xxxxxxx.tar.gz 并解压
    确保电脑配置了 ANDROID_HOME 环境变量,修改脚本中对应的 ndk 版本号
    如果是32位架构,HOST 改为 armv7a,API 修改为对应手机的 Android 系统版本
    脚本如下:
bash 复制代码
#!/bin/bash

export TOOLCHAIN=$ANDROID_HOME/ndk/29.0.14206865/toolchains/llvm/prebuilt/darwin-x86_64
export HOST=aarch64-linux-android
export API=29
export CC=$TOOLCHAIN/bin/$HOST$API-clang
export CXX=$TOOLCHAIN/bin/$HOST$API-clang++
export AR=$TOOLCHAIN/bin/$HOST-ar
export AS=$TOOLCHAIN/bin/$HOST-as
export LD=$TOOLCHAIN/bin/$HOST-ld
export RANLIB=$TOOLCHAIN/bin/$HOST-ranlib
export STRIP=$TOOLCHAIN/bin/$HOST-strip
export CFLAGS="-mthumb -fpic -ffunction-sections -funwind-tables -fstack-protector-all -fno-strict-aliasing"
export CXXFLAGS="$CFLAGS -frtti -fexceptions"

./configure --prefix=`pwd`/build/sqlite3/ \
            --host=$HOST \
            --enable-shared \
            --disable-static
            
if [ $? -eq 0 ]; then
    make clean
    make -j16
    make install
fi
  1. push 到 /bin
bash 复制代码
adb -s e102dcb0 push `pwd`/build/sqlite3/bin/sqlite3 /sdcard
adb -s e102dcb0 shell << EOF
  su

  # 0. 移动sqlite3
  mv /sdcard/sqlite3 /data/local/tmp
	
	# 1. 定义模块目录变量
	MODDIR=/data/adb/modules/custom_path
	
	# 2. 创建目录
	mkdir -p $MODDIR/system/etc
	
	# 3. 写入 mkshrc 文件
	cat > $MODDIR/system/etc/mkshrc << 'EOF'
	# 为所有 shell(adb shell、终端模拟器、su 后的 shell)添加自定义 PATH
	export PATH=$PATH:/data/local/tmp
	EOF
	
	# 4. 写入模块属性文件
	cat > $MODDIR/module.prop << 'EOF'
	id=custom_path
	name=Custom PATH
	version=1
	versionCode=1
	author=equuleus
	description=Add /data/local/tmp to PATH for all shells
	EOF
	
	# 5. 设置权限
	chmod -R 755 $MODDIR
	chmod 644 $MODDIR/system/etc/mkshrc
	
	# 6. 验证文件已创建
	ls -l $MODDIR
	ls -l $MODDIR/system/etc/

  # 7.重启手机
  reboot

EOF

cd 到源码目录执行上述脚本会生成 sqlite3 可执行文件,如果你的手机已经是完全 root 过的,则直接 push 到 /system/xbin/ 即可。

但是我的手机是借助 magisk 来开启 root 权限的,是没有 system 分区的写权限的,这里我们先将 sqlite3 push 到 /sdcard 目录下,然后需要编写一个 magisk 模块 custom_path 来开启读写权限。

安装好 custom_path 模块后,重启执行 sqlite3 --version 。

bash 复制代码
(base) longwei@Mac-Pro ~ % adb -s e102dcb0 shell
$ su
# echo $PATH
/sbin:/system/sbin:/product/bin:/apex/com.android.runtime/bin:/system/bin:/system/xbin:/odm/bin:/vendor/bin:/vendor/xbin:/data/local/tmp:/data/local/tmp
# sqlite3 --version
3.51.3 2026-03-13 10:38:09 737ae4a34738ffa0c3ff7f9bb18df914dd1cad163f28fd6b6e114a344fe6d618 (64-bit)
相关推荐
WL_Aurora4 分钟前
Java字符输入全攻略
java·开发语言
Hello.Reader21 分钟前
算法基础(十三)——随机算法为什么有时主动引入随机性
java·数据库·算法
likerhood25 分钟前
ConcurrentHashMap底层数据结构和面试常见问题
java·数据结构·面试·hashmap
云烟成雨TD34 分钟前
Spring AI Alibaba 1.x 系列【52】Interrupts 中断机制:案例演示
java·人工智能·spring
老鱼说AI39 分钟前
现代 LangChain 开发指南:从 LCEL 原理到企业级 RAG 与 Agent 实战
java·开发语言·人工智能·深度学习·神经网络·算法·机器学习
cwzqf1 小时前
Jectpack Compose项目组件代码分享(1):分页加载组件
android
云烟成雨TD1 小时前
Spring AI Alibaba 1.x 系列【51】Graph 整体运行全流程
java·人工智能·spring
@北海怪兽1 小时前
SQL常见函数整理 _ STRING_AGG()
android·数据库·sql
霑潇雨1 小时前
Spark学习基础转换算子案例(单词计数(WordCount))
java·大数据·分布式·学习·spark·maven
夏日听雨眠2 小时前
Linux(信号,管道,共享内存)
java·服务器·网络