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这个可执行文件来 创建数据库、建表等操作了。

相关推荐
不爱学英文的码字机器2 分钟前
[Linux] Shell 命令及运行原理
linux·运维·服务器
cdut_suye13 分钟前
Linux工具使用指南:从apt管理、gcc编译到makefile构建与gdb调试
java·linux·运维·服务器·c++·人工智能·python
qq_4336184417 分钟前
shell 编程(三)
linux·运维·服务器
Tlzns38 分钟前
Linux网络——UDP的运用
linux·网络·udp
码农土豆1 小时前
PaddlePaddle飞桨Linux系统Docker版安装
linux·docker·paddlepaddle
Hacker_xingchen1 小时前
天融信Linux系统安全问题
linux·运维·系统安全
张暮笛1 小时前
抓取手机HCI日志
linux
大猫和小黄1 小时前
Windows、CentOS环境下搭建自己的版本管理资料库:GitBlit
linux·服务器·windows·git
Joyner20181 小时前
【Linux】ubuntu通过远程命令行启动桌面应用
linux·服务器·ubuntu
ghostwritten1 小时前
Linux Swap: 深入解析 mkswap, mkfs.swap, 和 swapon
linux·运维·服务器