Windows 10
SQL Server 2019
Python 3.9.1
Django 3.2.5
pip freeze:
asgiref==3.4.1
Django==3.2.5
django-mssql-backend==2.8.1
djangorestframework==3.12.4
pyodbc==4.0.30
pytz==2021.1
sqlparse==0.4.1 DATABASES = {
'default': {
'ENGINE': 'sql_server.pyodbc',
'NAME': 'dbForDjango',
'USER': 'sa',
'PASSWORD': 'sdf874sd21',
'HOST': 'DESKTOP-AR76KF2\SQL_SERVER',
'PORT': '',
'OPTIONS': {
'driver': 'ODBC Driver 17 for SQL Server',
},
},
},我可以毫无问题地运行服务器,而且py manage.py外壳也能工作,但是Django根本无法与数据库通信。
命令"py manage.py dbshell“发生以下错误:

请忽略目录名"playingWithFastAPI",它使用的是Django而不是FastAPI :)
py manage.py迁移发生错误:

发布于 2021-07-02 18:50:41
dbshell错误是一个已知的问题(请参阅https://github.com/ESSolutions/django-mssql-backend/issues/100),因为Django -mssql-后端与Django 3.1+不兼容。
发布于 2021-09-10 11:31:04
因此,对于Django版本超过3.2,您必须使用mssql。https://learn.microsoft.com/en-us/samples/azure-samples/mssql-django-samples/mssql-django-samples/和古德勒克给你
py -m pip install django mssql-django
# settings.py
DATABASES = {
"default": {
"ENGINE": "mssql",
"NAME": "DATABASE_NAME",
"USER": "USER_NAME",
"PASSWORD": "PASSWORD",
"HOST": "HOST_ADDRESS",
"PORT": "1433",
"OPTIONS": {"driver": "ODBC Driver 17 for SQL Server",
},
},
}https://stackoverflow.com/questions/68229993
复制相似问题