SQLite3库链接与加载问题解决方案

orangepi@orangepizero2:~/embedded_Database/sqlite ls /usr/local/lib/ libsqlite3.a libsqlite3.so.0 libwiringPiDev.so libwiringPi.so pkgconfig python3.6 libsqlite3.so libsqlite3.so.3.50.4 libwiringPiDev.so.2.58 libwiringPi.so.2.58 python2.7 orangepi@orangepizero2:\~/embedded_Database/sqlite orangepi@orangepizero2:~/embedded_Database/sqlite orangepi@orangepizero2:\~/embedded_Database/sqlite gcc openSqlite.c -lsqlite3 orangepi@orangepizero2:~/embedded_Database/sqlite ./a.out ./a.out: error while loading shared libraries: libsqlite3.so: cannot open shared object file: No such file or directory orangepi@orangepizero2:\~/embedded_Database/sqlite

输出可以看到,libsqlite3.so 确实存在于 /usr/local/lib/,但运行时仍然找不到。这是因为 Linux 默认不会自动搜索 /usr/local/lib/ 下的共享库(.so 文件),除非该路径被添加到动态链接器的搜索路径中。

解决方法

cpp 复制代码
方法 1:临时添加 /usr/local/lib/ 到 LD_LIBRARY_PATH(仅当前终端有效)
export LD_LIBRARY_PATH=/usr/local/lib:$LD_LIBRARY_PATH
./a.out
这样,程序运行时就会在 /usr/local/lib/ 下查找 libsqlite3.so。

方法 2:永久添加 /usr/local/lib/ 到系统库搜索路径
(推荐)方法 
2.1:更新 /etc/ld.so.conf
    检查 /etc/ld.so.conf 是否包含 /usr/local/lib/:
    cat /etc/ld.so.conf
    如果没有,可以手动添加:
    sudo sh -c "echo '/usr/local/lib' >> /etc/ld.so.conf"
    更新动态链接器的缓存:
    sudo ldconfig
    再次运行程序:
    ./a.out

方法 2.2:
    在 /etc/ld.so.conf.d/ 下创建新配置文件
    echo '/usr/local/lib' | sudo tee /etc/ld.so.conf.d/local_lib.conf
    sudo ldconfig
    ./a.out

方法 3:编译时指定运行时库路径(避免修改系统配置)
    gcc openSqlite.c -lsqlite3 -Wl,-rpath=/usr/local/lib -o a.out
    -Wl,-rpath=/usr/local/lib 告诉链接器在运行时优先从 /usr/local/lib 加载共享库。
    这样即使 LD_LIBRARY_PATH 没有设置,程序也能找到 libsqlite3.so。

方法 4:静态链接 SQLite3(完全避免动态库依赖)
    gcc openSqlite.c /usr/local/lib/libsqlite3.a -o a.out
    这样编译后,a.out 会直接包含 SQLite3 的代码,不再依赖 libsqlite3.so。

为什么会出现这个问题?
    Linux 默认只搜索 /lib 和 /usr/lib,而 /usr/local/lib 通常需要手动配置。
    你的 libsqlite3.so 在 /usr/local/lib/,但动态链接器(ld.so)默认不会搜索这个路径。
    通过 LD_LIBRARY_PATH、ldconfig 或 -rpath 可以解决这个问题。

验证是否解决
    运行:
    ldd ./a.out
    如果输出显示 libsqlite3.so 已经正确找到(而不是 not found),说明问题已解决。

总结
    ✅ 推荐方法:

    临时测试:export LD_LIBRARY_PATH=/usr/local/lib:$LD_LIBRARY_PATH

    永久解决:sudo ldconfig(确保 /usr/local/lib 在 ld.so.conf 里)

    编译时指定路径:gcc ... -Wl,-rpath=/usr/local/lib

这样应该就能让 ./a.out 正常运行了! 🚀
相关推荐
倔强的石头_13 小时前
《Kingbase护城河》——猎捕慢查询:执行计划的微观解析与索引调优实战
数据库
SelectDB15 小时前
Apache Doris Python UDF:让 SQL 直接调用 Python 生态,支撑 Agent 时代复杂业务逻辑
大数据·数据库·python
jiayou642 天前
KingbaseES 表级与列级加密完全指南
数据库·后端
GBASE3 天前
G术时刻 |GBase 8s数据库事务并发控制之封锁技术介绍(下)
数据库
xiezhr3 天前
逛GitHub发现了一款免费的带AI功能的数据库管理工具
数据库·ai编程·dba
吃糖的小孩4 天前
给 QQ AI 机器人设计“可控记忆”:会话摘要、手动长期记忆与角色卡边界
数据库
笃行3505 天前
金仓数据库数据安全双防线:静态存储加密与传输加密实战
数据库
笃行3505 天前
金仓数据库物理备份实战:sys_rman 全流程演练与误覆盖抢救
数据库
笃行3505 天前
金仓数据库逻辑备份实战:从全库导出到 Schema 替换的完整闭环
数据库