将 Django 从 2.1 升级到 2.2.13 时如何修复 pyodbc 依赖性错误?

How to fix pyodbc dependency errors when upgrade Django from 2.1 to 2.2.13?

由于版本 2.1 已被标记为不安全,我需要至少升级到 >=2.2。 Github 安全建议安装 2.2.13。我还需要安装其他只适用于 Django >=2.2.

的包

Django 升级成功,但当 pipenv 尝试锁定依赖项时出现此错误:

Warning: Your dependencies could not be resolved. You likely have a mismatch in your sub-dependencies.

我用谷歌搜索了这个,我不再收到这个错误的唯一方法是将这两个依赖项放在 [dev-packages] 下:

django-pyodbc-azure = "<2.1"
django-pyodbc = "<2.1"

但是当我尝试 运行 服务器时,我得到了这个:

ImproperlyConfigured("Django %d.%d.%d is not supported." % VERSION[:3])
django.core.exceptions.ImproperlyConfigured: Django 2.2.13 is not supported.

我也用谷歌搜索了这个,显示的解决方案是手动更改引发此错误的条件。我这样做了,然后我得到了另一个错误:

django.core.exceptions.ImproperlyConfigured: 'sql_server.pyodbc' isn't an available database backend.
Try using 'django.db.backends.XXX', where XXX is one of:
    'mysql', 'oracle', 'postgresql', 'sqlite3'

我也用谷歌搜索了这个,但对其他人有用的解决方案对我不起作用。我已经被困在这一点上好几天了。请发送帮助!

其他信息: 我正在使用这两个参数:

ENGINE':'sql_server.pyodbc'
'driver': 'ODBC Driver 17 for SQL Server'

注意:如果您知道我可以将这些包与较新版本的 Django 一起使用的另一种方法,请分享它。

不幸的是,

django-pyodbc-azure 不再维护。您可以使用一个新包作为直接替代品。它支持 Django 2.2 和 3.0。

https://pypi.org/project/django-mssql-backend/

我建议您完全删除对 pyodbcdjango-pyodbcdjango-pyodbc-azure 的所有引用。然后更新您的依赖项(例如,在 Pipfilerequirements.txt 中)以添加:

django-mssql-backend==2.8.1
django>=2.2,<3

当您有机会确保没有 django-pyodbc-azure 闲逛时,请在新的虚拟环境中尝试一下。如果您有任何其他问题,我们可以在评论中解决它们并修改答案。我认为您不需要它,但我在这里提供了更深入的指南:https://www.pyphilly.org/django-and-sql-server-2020-edition/