django|报错SQLite 3.8.3 or later is required的解决方案

迁移原同事写的程序,到新服务器上边。运行报错。解决方案有三种

  1. 降低django版本
  2. 升级sqlite3,不低于3.8.3版本
  3. 修改django源码

方案一、降低django版本

卸载高版本django

复制代码
pip uninstall django

安装低版本,如

复制代码
pip install django==2.1.7

注意:如果是生产环境或者项目规定了django版本,降低django版本显然不合适,最好的解决方案是升级sqlite3的版本

方案二、升级sqlite3版本

升级sqlite3版本的主要步骤有:

  • 下载不低于3.8.3版本的sqlite3
  • 解压并安装sqlite3
  • 设置软链接
  • 修改.bashrc文件

下载sqlite3

复制代码
wget https://www.sqlite.org/2019/sqlite-autoconf-3270200.tar.gz

解压并安装sqlite3

复制代码
$ tar -zxvf sqlite-autoconf-3270200.tar.gz
$ cd sqlite-autoconf-3270200
$ ./configure --prefix=/usr/local
$ make && make install

设置软链接

复制代码
$ mv /usr/bin/sqlite3  /usr/bin/sqlite3_old
$ ln -s /usr/local/bin/sqlite3   /usr/bin/sqlite3

修改.bashrc文件

在用户目录下.bashrc文件最后一行添加export LD_LIBRARY_PATH="/usr/local/lib"

并在终端输入立即生效命令source ~/.bashrc

方案三、修改django源码

在django安装包里,找到/.../lib/python3.6/site-packages/django/db/backends/sqlite3/base.py脚本,找到判断sqlite版本的代码,注释掉并更改如下:

复制代码
def check_sqlite_version():
    # if Database.sqlite_version_info < (3, 8, 3):
    if Database.sqlite_version_info < (3, 6, 3):
        raise ImproperlyConfigured('SQLite 3.6.3 or later is required(found %s).' % Database.sqlite_version)

方案三修改了django源码,存在未知风险,不建议使用。

相关推荐
咸蛋Superman21 小时前
靠谱的车联网时序数据库服务商有哪些
数据库·时序数据库
AIHE-TECH21 小时前
多台西门子PLC控制器与SQL数据库对接(带边缘计算)的案例
数据库·sql·mysql·边缘计算·达梦数据库·西门子plc·智能网关
思成不止于此21 小时前
【MySQL 零基础入门】MySQL 函数精讲(二):日期函数与流程控制函数篇
android·数据库·笔记·sql·学习·mysql
九章-21 小时前
教育信创落地新实践:三亚技师学院完成教育平台数据库国产化,打造职业院校自主可控轻量级样板
数据库·安全
码河漫步21 小时前
win11下mysql数据库设置主从
数据库·mysql
Stone_OverLooking1 天前
Qt6.5.3 mingw64 Ninja编译oracle oci驱动
数据库·qt·oracle
Java爱好狂.1 天前
如何用JAVA技术设计一个高并发系统?
java·数据库·高并发·架构设计·java面试·java架构师·java八股文
慌糖1 天前
读书笔记之MySQL的字符集与比较规则小读
数据库
码农很忙1 天前
从0到1搭建智能分析OBS埋点数据的AI Agent:实战指南
数据库·人工智能
安当加密1 天前
Oracle数据库透明加密实践:基于TDE架构的安全加固方案
数据库·oracle·架构