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 正常运行了! 🚀
相关推荐
与衫21 小时前
在 VS Code 里看清你的数据流向:Gudu SQL Omni 实测体验
数据库·sql
Element_南笙21 小时前
吴恩达新课程:Agentic AI(笔记2)
数据库·人工智能·笔记·python·深度学习·ui·自然语言处理
长安城没有风21 小时前
从入门到精通【Redis】Redis 典型应⽤ --- 分布式锁
数据库·redis·分布式
Ytadpole21 小时前
MySQL 数据库优化设计:优化原理和数据库表设计技巧
数据库·mysql·优化·索引·查询·检索·表设计
christine-rr1 天前
数据库基础概念体系梳理
数据库·oracle
SirLancelot11 天前
StarRocks-基本介绍(一)基本概念、特点、适用场景
大数据·数据库·数据仓库·sql·数据分析·database·数据库架构
Boop_wu1 天前
[MySQL] 基础操作
数据库·mysql
6极地诈唬1 天前
【sqlite】xxx.db-journal是什么?
数据库·sqlite
小糖学代码1 天前
MySQL:14.mysql connect
android·数据库·mysql·adb