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源码,存在未知风险,不建议使用。

相关推荐
这个DBA有点耶43 分钟前
GROUP BY优化全解:如何写出既不丢数据又飞快的分组查询
数据库·mysql·架构
掉头发的王富贵4 小时前
【StarRocks】极限十分钟入门StarRocks
数据库·sql·mysql
Nturmoils4 小时前
WHERE 条件别凭习惯写,常用查询先跑一遍
数据库
Databend1 天前
在 AWS 中国峰会逛了一天,我在 Databend 展台看到了 Agent 数据基础设施的新思路
数据库·人工智能·agent
ClouGence2 天前
Oracle 数据同步为什么会出现数据不一致?长事务是常被忽略的原因
数据库·后端·oracle
飞将2 天前
从零实现数据库(2)——HashIndex + IndexManager
数据库
兵慌码乱3 天前
面向桌面端的资产管理系统分层架构设计与核心模块实现
python·系统架构·sqlite·pyqt5·数据库设计·桌面应用开发·mvc架构
呱呱复呱呱3 天前
Django CBV 源码解读:一个请求是怎么找到你的 get() 方法的
python·django
Nturmoils3 天前
订单列表慢查询,先看 WHERE、ORDER BY 和 LIMIT
数据库
渣波3 天前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端