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

相关推荐
齐齐大魔王1 天前
linux-僵死进程处理
linux·运维·服务器
wuminyu1 天前
专家视角看Java字节码加载与存储指令机制
java·linux·c语言·jvm·c++
.小小陈.1 天前
Linux 线程概念与控制:从底层原理到实战应用
linux·运维·jvm
网络工程小王1 天前
【LangChain 大模型6大调用指南】调用大模型篇
linux·运维·服务器·人工智能·学习
wangbing11251 天前
各linux版本的包管理命令
linux·运维·服务器
Joseph Cooper1 天前
Linux/Android 跟踪技术:ftrace、TRACE_EVENT、atrace、systrace 与 perfetto 入门
android·linux·运维
比昨天多敲两行1 天前
Linux基础开发工具(下)
linux·运维·服务器
笨笨饿1 天前
69_如何给自己手搓一个串口
linux·c语言·网络·单片机·嵌入式硬件·算法·个人开发
cn_lyg1 天前
Linux的入门级常用操作命令
linux·运维·服务器
就叫飞六吧1 天前
TOML vs YAML:为什么 Cargo 选择 TOML?
linux·运维·服务器