Aquí hay una respuesta "moderna" a esta pregunta. Implementé con éxito Django 1.11 en un servidor de producción Ubuntu 16.04 que se conecta a MS SQL Server 2017 ejecutándose en otro servidor.
primer lugar, instale el controlador nativo de MS ODBC "de controladores ODBC 17 para SQL Server":
# https://docs.microsoft.com/en-us/sql/connect/odbc/linux-mac/installing-the-microsoft-odbc-driver-for-sql-server#ubuntu-1404-1604-and-1710
sudo su
curl https://packages.microsoft.com/keys/microsoft.asc | apt-key add -
curl https://packages.microsoft.com/config/ubuntu/16.04/prod.list > /etc/apt/sources.list.d/mssql-release.list
apt-get update
ACCEPT_EULA=Y apt-get install msodbcsql
apt-get install unixodbc-dev
# test you can actually get to port 1433 on the server that is running MS SQL:
nc -z -v -w5 host.where.sql.server.is.running.com 1433
# add /opt/mssql-tools/bin to your PATH in .bash_profile, e.g.:
# PATH="$HOME/bin:$HOME/.local/bin:/opt/mssql-tools/bin:$PATH"
# source ~/.bash_profile
# now, test that you can actually connect to MS SQL Server:
sqlcmd -S host.where.sql.server.is.running.com -U db_username -P db_password
En segundo lugar, asegúrese de que pip install
estos módulos:
# https://github.com/michiya/django-pyodbc-azure
django-pyodbc-azure==1.11.9.0
# https://github.com/mkleehammer/pyodbc/wiki
pyodbc==4.0.22
En tercer lugar, modificar la entrada BASES DE DATOS de su Django settings.py
:
DATABASES = {
'default': {
'ENGINE': 'sql_server.pyodbc',
'NAME': 'db_name',
'USER': 'db_username',
'PASSWORD': 'db_password',
'HOST': 'host.where.sql.server.is.running.com',
'PORT': '1433',
'OPTIONS': {
'driver': 'ODBC Driver 17 for SQL Server',
},
},
}
Estoy omitiendo t El resto de mi configuración (nginx, Gunicorn, Django REST Framework, etc.), pero eso está fuera del alcance de esta respuesta.
Gracias por 'adodbapi' - esta fue una nueva para mí. –
django-mssql usa un tenedor de adodbapi y admite procedimientos almacenados. – Manfre
Puede obtener los resultados de los procedimientos almacenados de SQLServer llamándolos de la siguiente manera: 'cursor.execute ('DECLARAR @resultados int; EXEC @ resultados = spMyProc; SELECCIONAR @resultados')' –