CentOS 7 用户必看SQLite 升级指南:轻松将旧版 3.7.17 升级至3.41.2详细教程

0.背景

编写此文是因为在 Linux 上跑项目时报错:

sqlite3.NotSupportedError: deterministic=True requires SQLite 3.8.3 or highe(此时已经安装了 python3)。
sqlalchemy.exc.OperationalError: (sqlite3.OperationalError) near "(": syntax error
[SQL: SELECT anon_1.document_id AS anon_1_document_id 
FROM (SELECT document.id AS document_id, row_number() OVER (ORDER BY document.id) AS rownum 
FROM document) AS anon_1 
WHERE rownum % 10000=1]

查询之后发现是因为 centos 上的 sqlite3 版本过低导致。

去验证一下:在 centos 上进入 python,可以看到 sqlite3 的版本为 3.7.17。

Python 3.8.12 (default, Jun 21 2019, 00:36:41)
[GCC 4.8.5 20150623 (Red Hat 4.8.5-36)] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> import sqlite3
>>> sqlite3.sqlite_version
'3.7.17'
>>> exit()

原因已经找到,下面开始执行。

1、下载、编译、安装新版 [SQLite]

1.1 下载新版 sqlite

  • 首先去官网下载对应版本

  • 官网 https://sqlite.org/download.html

(1)下载前需要建立一个文件夹,用于放置压缩包。此处选择 / home 为主目录,可以根据自身习惯更改下载存储地址。

mkdir /home/tools/sqlite3

(2)使用 wget 下载

到 SQLite 官网的下载页面:https://sqlite.org/download.html 这里是最新的版本。
在这里插入图片描述

1.2 历史版本下载

  • 3.41.2版本 https://www.sqlite.org/cgi/src/info/0d1fc92f94cb6b76
  • 全部版本 https://www.sqlite.org/cgi/src/taglist
    step1:挑选版本: 以3.41.2为例
    在这里插入图片描述
    step2: 进入下载链接,选则为Classic View

在这里插入图片描述
点击[0d1fc92f]

step3: 选择下载版本则可

在这里插入图片描述
右击复制下载链接

cd /home/tools/sqlite3  #切换到下载路径
wget https://www.sqlite.org/cgi/src/zip/0d1fc92f/SQLite-0d1fc92f.zip  #执行下载

等待下载完毕即可

step4: 解压

unzip SQLite-0d1fc92f.zip

解压后可以看到有新的文件夹:SQLite-0d1fc92f,进入该目录进行 sqlite3 的编译和安装。
在这里插入图片描述

cd SQLite-0d1fc92f

1.3. 编译和安装

  • (1)新建安装目录(根据自己习惯选择安装路径)
mkdir /usr/local/sqlite3.42
  • (2)编译
./configure --prefix=/usr/local/sqlite3.42/

固定语法,‘–prefix’后接安装路径。结束时提示:Complete! 即可

  • (3)安装
make clean   # 清除缓存
make && make install  # 安装

提示:Successfully… 即可,否则清除缓存后,重新编译

以上述方式安装后,会把编译好的二进制文件安装到/usr/local/sqlite3.42/lib, 把头文件sqlite3.h sqlite3ext.h安装到/usr/local/sqlite3.42/include,我们需要知道这两个路径。

  • (4)建立软连接(快捷方式)
cd /usr/bin   # 切换到bin路径
ls -la sqlite*  # 查看sqlite已经存在的软连接
若提示:ls: cannot access sqlite*: No such file or directory。则还未建立软连接,直接执行下面的代码,建立软连接即可
ln -s /usr/local/sqlite3.42/bin/sqlite3 /usr/bin/sqlite3

注:其中/usr/local/sqlite3.42/bin/sqlite3为 sqlite3 的安装路径下的 bin 路径中的 sqlite3,/usr/bin/sqlite3为固定位置

若显示
在这里插入图片描述

需要先删除该软连接,再新建

rm -rf sqlite3   # 删除
ln -s /usr/local/sqlite3.42/bin/sqlite3 /usr/bin/sqlite3   # 新建
ls -la sqlite*  # 查看软连接
sqlite3 --version  # 查看版本
python
import sqlite3  
print(sqlite3.sqlite_version)

最终效果为

在这里插入图片描述

  • (5)配置系统 lib 库
    终端运行
echo "/usr/local/sqlite3.42/lib" > /etc/ld.so.conf.d/sqlite3.conf
ldconfig

2、卸载 python3

如果上述不行,

因为 sqlite3 是在 python3 安装时进行连接的,我的云服务器已经安装过了,所以需要卸载,如果还没有安装 python3 的,可以跳过这一步。

注:此处仅删除 python3,尽量别删除原装的 python2.7.5,因为 centos7 有一些命令是依赖 2.7.5 的。

whereis python3 |xargs rm -frv   # 此为强制删除,也可以使用yum命令删除

3、下载、编译和安装 Python3

3.1. 下载

下载方法和 sqlite3 的下载相似。本文安装的 python3.8.12 版本,官网地址为:https://www.python.org/ftp/python/3.8.12/

mkdir /home/tools/python3    # 新建下载存储路径
cd /home/tools/python3    # 切换到存储路径
wget https://www.python.org/ftp/python/3.8.12/Python-3.8.12.tar.xz  # 使用wget直接下载

同样的,也可以在本地下载之后,通过 ftp 上传。

tar -zxvf Python-3.8.12.tgz  # 解压

解压之后可以看到多了一个文件夹,直接切换过去

cd Python-3.8.12/

3.2. 编译安装

  • (1)安装

编译安装之前建议在 / usr/local 路径下建立安装路径(根据自身习惯选择)

mkdir /usr/local/python3

原本 python3 的编译为下面的方法,但是,没有加参数的默认安装,python 会自动导入原版本的 sqlite3.7.17,

cd /home/tools/python/Python-3.8.12/   # 切换到解压后的路径
./configure --prefix=/usr/local/python3  # 编译,‘--prefix’后接安装路径
make clean   # 清除缓存
make && make install   # 安装 

将上述代码修改为:

cd /home/tools/python/Python-3.8.12/   # 切换到解压后的路径
# 编译,‘--prefix’后接安装路径,其中LD_RUN_PATH和LDFLAGS为sqlite3的二进制文件位置路径,CPPFLAGS是头文件的位置路径。上面安装sqlite3时已经提到。
LD_RUN_PATH=/usr/local/sqlite3.42/lib/ ./configure LDFLAGS="-L/usr/local/sqlite3.42/lib" CPPFLAGS="-I/usr/local/sqlite3.42/include"  --prefix=/usr/local/python3/LD_RUN_PATH=/usr/local/sqlite3.42/lib/ make  # 编译时将sqlite3的二进制文件路径添加到动态链接库的搜索路径中
make clean   # 清除缓存
make && make install  # 安装
  • (2)建立软连接(快捷方式)

建立方法与 sqlite3 的软连接建立方式相同

ls -la python*   # 查看python已存在的软连接

一般情况下,如果是新建立的系统,会存在以下三个软连接

以上软连接不做更改(因为很多系统命令会依赖 python2.7),直接新建一个 python3 的软连接即可

ln -s /usr/local/python3/bin/python3 /usr/bin/python3

最终效果

至此,sqlite3 和 python3 已经安装并且连接好了,可进行如下验证

[root@iZf8z170cg4zcnds9u2p10Z bin]# python3   # 进入python3
Python 3.8.12 (default, Jun  5 2023, 16:00:05) 
[GCC 4.8.5 20150623 (Red Hat 4.8.5-44)] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> import sqlite3
>>> sqlite3.sqlite_version
'3.42.0'
>>>exit()

可以看到,其中 python 版本为 3.8.12,并且 python3 内的 sqlite3 版本为 3.42.0,升级成功

参考链接:

https://blog.csdn.net/TAYLOR1219070261/article/details/131064076

https://blog.csdn.net/u012940672/article/details/122452092

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/576956.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

新/旧版本 QT 下载,全攻略【省资源下载币专用】

看到好多朋友找不到指定版本的QT下载路径,特此更新一篇新/旧版本 QT 下载攻略 收藏一下吧,需要的时候方便查找,能为你省下好多资源下载币。 通过图示可以看出,新旧版本的界限并没有那么明晰,如果你需要的版本两个链接…

Podman配置mongodb

文章目录 查询镜像拉取镜像查看镜像运行容器创建root用户 查询镜像 podman search mongo拉取镜像 podman pull docker.io/library/mongo查看镜像 podman images运行容器 podman run -d -p 27017:27017 --namemongodb-test docker.io/library/mongo创建root用户 podman exe…

AI Earth平台简介

AI Earth地球科学云平台由达摩院-视觉技术实验室打造,基于地球科学智能计算分析方面的创新研究,致力于解决地球科学领域基础性、前沿性、业务性问题,目标成为国内一流的地球科学云计算平台。(摘自官网) 下面&#xff…

网站数据统计基础:PV、UV与IP的解读

在数字时代,了解和分析网站流量至关重要。无论是新手网站所有者还是资深市场分析师,掌握如何解读网站的PV、UV和IP等指标对于评估网站表现、优化用户体验和制定有效市场策略都是必不可少的。以下是对这三个关键指标的详细介绍。 文章目录 1. PV&#xff…

网页乱码问题(edge浏览器)

网页乱码问题(edge) 文章目录 网页乱码问题(edge)前言一、网页乱码问题1.是什么:(描述)2.解决方法:(针对edge浏览器)(1)下载charset插…

k8s 组件

k8s: kubernets:8个字母省略,就是k8s. 自动部署,自动扩展和管理容器化的应用程序的一个开源系统。 k8s是负责自动化运维管理多个容器化程序的集群,是一个功能强大的容器编排工具。 以分布式和集群化的方式进行容器管理。 1.20面试版本 …

[PyTorch][chapter 8][李宏毅深度学习][DNN 训练技巧]

前言: DNN 是神经网络的里面基础核心模型之一.这里面结合DNN 介绍一下如何解决 深度学习里面过拟合,欠拟合问题 目录: DNN 训练常见问题 过拟合处理 欠拟合处理 keras 项目 一 DNN 训练常见问题 我们在深度学习网络训练的时候经常会遇到下面…

Oracle初始化参数修改后,是否需要重启才能生效

可以查看 v$parameter或v$parameter2动态性能视图的ISSYS_MODIFIABLE列。此列指示是否可以使用 ALTER SYSTEM 更改参数以及更改何时生效: IMMEDIATE - 无论用于启动实例的参数文件的类型如何,都可以使用 ALTER SYSTEM 更改参数。 更改立即生效。DEFERRE…

易基因2023年度DNA甲基化研究项目文章精选

大家好,这里是专注表观组学十余年,领跑多组学科研服务的易基因。 2023年,易基因参与的DNA甲基化研究成果层出不穷,小编选取其中5篇不同方向的论文与您一起来回顾。 01、易基因微量DNA甲基化测序助力中国科学家成功构建胚胎干细胞…

工厂设备维护管理有什么比较好的解决方案?哪家的工单管理系统功能强大?

生产设备对于工厂来说是十分宝贵的资产。一方面,工厂依赖设备进行生产活动,一旦设备故障就会影响产量;另一方面,工厂中的生产设备一般造价都比较高昂,如果出现故障就会增加工厂的生产成本;再一方面&#xf…

Linux部署MeterSphere结合内网穿透实现远程访问服务管理界面

文章目录 前言1. 安装MeterSphere2. 本地访问MeterSphere3. 安装 cpolar内网穿透软件4. 配置MeterSphere公网访问地址5. 公网远程访问MeterSphere6. 固定MeterSphere公网地址 前言 MeterSphere 是一站式开源持续测试平台, 涵盖测试跟踪、接口测试、UI 测试和性能测试等功能&am…

makefile教程(1)

makefile教程 makefile是什么: makefile是用户自行完成的IDE(integrated development environment集成开发环境)程序,与传统的操作系统下的编译不同,makefile可以通过用户自行安排,决定文件的编译顺序&am…

第 377 场周赛虚拟参赛记录及补题

最小数字游戏 3 题目 - 思路 模拟代码 class Solution { public:vector<int> numberGame(vector<int>& nums) {sort(nums.begin(),nums.end());vector<int> ans;for (int i 0;i < nums.size();i ) if (i&1)ans.push_back(nums[i-1]);else ans.…

postman的下载安装和使用

第一章、使用postman向后端发送请求 1.2&#xff09;postman下载与安装使用 我的百度网盘postman点击下载 提取码&#xff1a;bybp 下载后双击.exe文件直接安装 点击此次创建集合 点击此处创建请求 1.2&#xff09;发送get请求 选择自己的请求方式&#xff0c;输入请求…

Uboot

这里写目录标题 什么是Bootloader?Bootloader启动流程NAND Flash uboot是怎么和内核完成参数传递的&#xff1f; 什么是Bootloader? Linux系统要启动就必须需要一个 bootloader程序&#xff0c;也就说芯片上电以后先运行一段bootloader程序。 这段 **bootloader程序会先初始…

使用 FFmpeg 清除文件夹下所有 .mp4 文件声音

运行以下命令来清除声音&#xff1a; ffmpeg -i input.mp4 -c copy -an output.mp4这个命令会将 “input.mp4” 替换为你要处理的 .mp4 文件名。它会生成一个新的文件名为 “output.mp4” 的文件&#xff0c;该文件是没有声音的副本。 如果你想要直接替换原始文件&#xff0c;…

【网络编程】基于UDP数据报实现回显服务器程序

个人主页&#xff1a;兜里有颗棉花糖 欢迎 点赞&#x1f44d; 收藏✨ 留言✉ 加关注&#x1f493;本文由 兜里有颗棉花糖 原创 收录于专栏【网络编程】【Java系列】 本专栏旨在分享学习网络编程的一点学习心得&#xff0c;欢迎大家在评论区交流讨论&#x1f48c; 前言 我们如果…

互联网+建筑工地:技术革新引领建筑行业的未来

随着科技的飞速发展&#xff0c;互联网正日益渗透到建筑工地的方方面面。从设计、施工到管理&#xff0c;互联网建筑工地的深度融合不仅推动了建筑行业的数字化转型&#xff0c;还为工地管理、信息交流、安全监控等带来了全新的解决方案。本文将介绍互联网建筑工地的几个关键技…

java.lang.EnumConstantNotPresentException

枚举常量不存在异常。当应用试图通过名称和枚举类型访问一个枚举对象&#xff0c;但该枚举对象并不包含常量时&#xff0c;抛出该异常 1.遇到的问题是我删除了带有CustomAnnotation注解的类,启动服务器还是会抛出异常 2.首先全局搜索了相关的枚举名字 确认没有引用。后发现项目…

keras 人工智能之VGGNet神经网络的图片识别训练

上期文章我们分享了如何使用LetNet体系结构来搭建一个图片识别的神经网络: 人工智能Keras的第一个图像分类器(CNN卷积神经网络的图片识别) 本期我们基于VGGNet神经网络来进行图片的识别,且增加图片的识别种类,当然你也可以增加更多的种类,本期代码跟往期代码有很大的相…