1
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 shell 也在工作,但 Django 根本无法与数据库通信。
命令“py manage.py dbshel​​l”出现这个错误:

在此处输入图像描述

请忽略目录名称“playingWithFastAPI”,我使用的是 Django 而不是 FastAPI :)

py manage.py migrate 发生该错误:

在此处输入图像描述

4

2 回答 2

2

dbshel​​l 错误是一个已知问题(请参阅https://github.com/ESSolutions/django-mssql-backend/issues/100),因为 django-mssql-backend 与 Django 3.1+ 不兼容

于 2021-07-02T18:50:41.383 回答
0

所以对于 3.2 以上的 Django 版本,你必须使用 mssql-django。 https://docs.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", 
        },
    },
}
于 2021-09-10T11:31:04.737 回答