Linux下从sqlite3源码编译出sqlite3库及相关可执行程序

目录

[1. 下载sqlite3源码并编译](#1. 下载sqlite3源码并编译)

[2. 下载Tcl库并编译](#2. 下载Tcl库并编译)

[3. 再次编译sqlite源码](#3. 再次编译sqlite源码)


1. 下载sqlite3源码并编译

打开SQLite Download Page,滚动到页面的下面,找到源码量最大的那个(其它的估计也行,但源码最大的本人感觉功能最全,截至2024年1月5号,源码最大的为13.42MiB),即单击下图红色链接下载源码:

执行如下命令解压:

bash 复制代码
unzip sqlite-src-3440200.zip

执行如下命令,创建构建目录:

bash 复制代码
cd sqlite-src-3440200
mkdir build

执行如下命令,编译:

bash 复制代码
cd build
../configure
make -j8

如果报如下错误,则转到第2节进行操作:

bash 复制代码
sqlite-src-3440200/build/../tool/cktclsh.sh: tclsh: not found
ERROR: This makefile target requires tclsh 8.4 or later.
Makefile:773: recipe for target 'has_tclsh84' failed
make: *** [has_tclsh84] Error 1

2. 下载Tcl库并编译

打开Download Tcl/Tk Sources页面,点击如下红色框所示链接下载(本人下载的是zip格式的,你也可以选择其它格式的文件)

执行如下命令解压:

bash 复制代码
unzip tcl8613-src.zip 

执行如下命令,创建构建目录:

bash 复制代码
cd tcl8.6.13
mkdir build

执行如下命令,编译、安装:

bash 复制代码
cd build
../unix/configure
make -j8
sudo make  install

默认安装在:

bash 复制代码
/usr/local/lib

执行如下命令,设置tcl库的搜索目录:

bash 复制代码
sudo vi /etc/profile

在文件末尾加入如下库的搜索目录:

bash 复制代码
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/local/lib

执行如下命令,以使库的搜索目录立刻在本终端有效:

bash 复制代码
source /etc/profile

或重启系统(对所有终端有效)

3. 再次编译sqlite源码

回到1节再次执行如下命令编译、安装:

bash 复制代码
make -j8

注意,不需要执行如下的安装命令:

bash 复制代码
sudo make install

执行完make,默认就安装到/usr/local/lib目录了,如下:

在build目录下生成了sqlite3可执行程序,如下:

执行如下命令,可以看看sqlite3的用法:

bash 复制代码
./sqlite3  -help

结果如下:

现在可以用sqlite3这个可执行文件来 创建数据库、建表等操作了。

相关推荐
平生不喜凡桃李20 小时前
浅谈 Linux 中 namespace 相关系统调用
java·linux·服务器
YMWM_20 小时前
【问题】thor上的cubLas
linux·python·thor
杨云龙UP21 小时前
mysqldump逻辑备份文件恢复总结:全库恢复、单库恢复,一篇讲明白
linux·运维·服务器·数据库·mysql·adb
舰长11521 小时前
linux系统服务器加固1、中风险 未设置登录失败处理功能和登录连接超时处理功能。2、中风险 未限制默认账户的访问权限。3、中风险 未实现管理用户的权限分离。
linux·运维·服务器
mounter6251 天前
Linux 7.0 重磅更新:详解 nullfs 如何重塑根文件系统挂载与内核线程隔离
linux·运维·服务器·kernel
色空大师1 天前
【网站搭建实操(一)环境部署】
java·linux·数据库·mysql·网站搭建
A.A呐1 天前
【Linux第十三章】缓冲区
linux·服务器
想唱rap1 天前
Linux线程
java·linux·运维·服务器·开发语言·mysql
cccccc语言我来了1 天前
Linux(9)操作系统
android·java·linux
Lueeee.1 天前
Linux驱动中为什么既有 sysfs,又有字符设备?以 DHT11 驱动为例彻底讲透
linux·驱动开发