Вот "современный" ответ на этот вопрос. Я успешно развернул Django 1.11 на сервере Ubuntu 16.04, который подключается к MS SQL Server 2017, работающему на другом сервере.
Во-первых, установить родной драйвер MS ODBC "ODBC Driver 17 для 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
Во-вторых, убедитесь, что вы pip install
эти модули:
# https://github.com/michiya/django-pyodbc-azure
django-pyodbc-azure==1.11.9.0
# https://github.com/mkleehammer/pyodbc/wiki
pyodbc==4.0.22
В-третьих, изменить запись DATABASES из ваших Джанго 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',
},
},
}
Я omitt (nginx, Gunicorn, Django REST Framework и т. д.), но это выходит за рамки этого ответа.
Спасибо за 'adodbapi' - это было для меня новым. –
django-mssql использует вилку adodbapi и поддерживает хранимые процедуры. – Manfre
Вы можете получить результаты из хранимых процедур SQLServer, вызвав их так: 'cursor.execute ('DECLARE @results int; EXEC @ results = spMyProc; SELECT @results')' –