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

2024-01-06 10:36

本文主要是介绍Linux下从sqlite3源码编译出sqlite3库及相关可执行程序,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

1. 下载sqlite3源码并编译

2. 下载Tcl库并编译

3. 再次编译sqlite源码


1. 下载sqlite3源码并编译

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

执行如下命令解压:

unzip sqlite-src-3440200.zip

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

cd sqlite-src-3440200
mkdir build

执行如下命令,编译: 

cd build
../configure
make -j8

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

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格式的,你也可以选择其它格式的文件)

执行如下命令解压:

unzip tcl8613-src.zip 

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

cd tcl8.6.13
mkdir build

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

cd build
../unix/configure
make -j8
sudo make  install

默认安装在:

/usr/local/lib

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

sudo vi /etc/profile

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

export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/local/lib

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

source /etc/profile

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

3. 再次编译sqlite源码

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

make -j8

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

sudo make install

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

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

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

./sqlite3  -help

 结果如下:

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

这篇关于Linux下从sqlite3源码编译出sqlite3库及相关可执行程序的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/576083

相关文章

Java 正则表达式URL 匹配与源码全解析

《Java正则表达式URL匹配与源码全解析》在Web应用开发中,我们经常需要对URL进行格式验证,今天我们结合Java的Pattern和Matcher类,深入理解正则表达式在实际应用中... 目录1.正则表达式分解:2. 添加域名匹配 (2)3. 添加路径和查询参数匹配 (3) 4. 最终优化版本5.设计思

Linux内核参数配置与验证详细指南

《Linux内核参数配置与验证详细指南》在Linux系统运维和性能优化中,内核参数(sysctl)的配置至关重要,本文主要来聊聊如何配置与验证这些Linux内核参数,希望对大家有一定的帮助... 目录1. 引言2. 内核参数的作用3. 如何设置内核参数3.1 临时设置(重启失效)3.2 永久设置(重启仍生效

kali linux 无法登录root的问题及解决方法

《kalilinux无法登录root的问题及解决方法》:本文主要介绍kalilinux无法登录root的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,... 目录kali linux 无法登录root1、问题描述1.1、本地登录root1.2、ssh远程登录root2、

Linux ls命令操作详解

《Linuxls命令操作详解》通过ls命令,我们可以查看指定目录下的文件和子目录,并结合不同的选项获取详细的文件信息,如权限、大小、修改时间等,:本文主要介绍Linuxls命令详解,需要的朋友可... 目录1. 命令简介2. 命令的基本语法和用法2.1 语法格式2.2 使用示例2.2.1 列出当前目录下的文

idea maven编译报错Java heap space的解决方法

《ideamaven编译报错Javaheapspace的解决方法》这篇文章主要为大家详细介绍了ideamaven编译报错Javaheapspace的相关解决方法,文中的示例代码讲解详细,感兴趣的... 目录1.增加 Maven 编译的堆内存2. 增加 IntelliJ IDEA 的堆内存3. 优化 Mave

Java调用C++动态库超详细步骤讲解(附源码)

《Java调用C++动态库超详细步骤讲解(附源码)》C语言因其高效和接近硬件的特性,时常会被用在性能要求较高或者需要直接操作硬件的场合,:本文主要介绍Java调用C++动态库的相关资料,文中通过代... 目录一、直接调用C++库第一步:动态库生成(vs2017+qt5.12.10)第二步:Java调用C++

Linux中的计划任务(crontab)使用方式

《Linux中的计划任务(crontab)使用方式》:本文主要介绍Linux中的计划任务(crontab)使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、前言1、linux的起源与发展2、什么是计划任务(crontab)二、crontab基础1、cro

Linux换行符的使用方法详解

《Linux换行符的使用方法详解》本文介绍了Linux中常用的换行符LF及其在文件中的表示,展示了如何使用sed命令替换换行符,并列举了与换行符处理相关的Linux命令,通过代码讲解的非常详细,需要的... 目录简介检测文件中的换行符使用 cat -A 查看换行符使用 od -c 检查字符换行符格式转换将

Java编译生成多个.class文件的原理和作用

《Java编译生成多个.class文件的原理和作用》作为一名经验丰富的开发者,在Java项目中执行编译后,可能会发现一个.java源文件有时会产生多个.class文件,从技术实现层面详细剖析这一现象... 目录一、内部类机制与.class文件生成成员内部类(常规内部类)局部内部类(方法内部类)匿名内部类二、

Linux系统配置NAT网络模式的详细步骤(附图文)

《Linux系统配置NAT网络模式的详细步骤(附图文)》本文详细指导如何在VMware环境下配置NAT网络模式,包括设置主机和虚拟机的IP地址、网关,以及针对Linux和Windows系统的具体步骤,... 目录一、配置NAT网络模式二、设置虚拟机交换机网关2.1 打开虚拟机2.2 管理员授权2.3 设置子