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

相关推荐
Hello.Reader8 分钟前
Redis 延迟监控深度指南
数据库·redis·缓存
ybq195133454319 分钟前
Redis-主从复制-分布式系统
java·数据库·redis
好奇的菜鸟3 小时前
如何在IntelliJ IDEA中设置数据库连接全局共享
java·数据库·intellij-idea
tan180°3 小时前
MySQL表的操作(3)
linux·数据库·c++·vscode·后端·mysql
满昕欢喜3 小时前
SQL Server从入门到项目实践(超值版)读书笔记 20
数据库·sql·sqlserver
Hello.Reader5 小时前
Redis 延迟排查与优化全攻略
数据库·redis·缓存
简佐义的博客6 小时前
破解非模式物种GO/KEGG注释难题
开发语言·数据库·后端·oracle·golang
爬山算法6 小时前
MySQL(116)如何监控负载均衡状态?
数据库·mysql·负载均衡
老纪的技术唠嗑局8 小时前
OceanBase PoC 经验总结(二)—— AP 业务
数据库
阿里云大数据AI技术9 小时前
OpenSearch 视频 RAG 实践
数据库·人工智能·llm