Я не могу подключить Django к SQL Server в Mac OS. Как подключить Django к докеру SQL Server в Mac OS?
Пип-установка
pip установить mssql-django
Параметр:
DATABASES = {
'default': {
'ENGINE': 'sql_server.pyodbc',
'NAME': 'test1',
'HOST': 'localhost',
'PORT': 1433,
'USER': 'SA',
'PASSWORD': 'xxxxx',
'OPTIONS': {
'driver': 'ODBC Driver 13 for SQL Server',
},
}
}
Запустите python3 Manage.py runserver, он отобразит сообщение об ошибке, как показано ниже. есть ли способ исправить эту ошибку?
ModuleNotFoundError: No module named 'sql_server'
The above exception was the direct cause of the following exception:
Traceback (most recent call last):
File "/Library/Frameworks/Python.framework/Versions/3.12/lib/python3.12/threading.py", line 1073, in _bootstrap_inner
self.run()
File "/Library/Frameworks/Python.framework/Versions/3.12/lib/python3.12/threading.py", line 1010, in run
self._target(*self._args, **self._kwargs)
File "/Users/imac/Desktop/Project/Test/myenv/lib/python3.12/site-packages/django/utils/autoreload.py", line 64, in wrapper
fn(*args, **kwargs)
File "/Users/imac/Desktop/Project/Test/myenv/lib/python3.12/site-packages/django/core/management/commands/runserver.py", line 125, in inner_run
autoreload.raise_last_exception()
File "/Users/imac/Desktop/Project/Test/myenv/lib/python3.12/site-packages/django/utils/autoreload.py", line 87, in raise_last_exception
raise _exception[1]
File "/Users/imac/Desktop/Project/Test/myenv/lib/python3.12/site-packages/django/core/management/__init__.py", line 394, in execute
autoreload.check_errors(django.setup)()
File "/Users/imac/Desktop/Project/Test/myenv/lib/python3.12/site-packages/django/utils/autoreload.py", line 64, in wrapper
fn(*args, **kwargs)
File "/Users/imac/Desktop/Project/Test/myenv/lib/python3.12/site-packages/django/__init__.py", line 24, in setup
apps.populate(settings.INSTALLED_APPS)
"/Users/imac/Desktop/Project/Test/myenv/lib/python3.12/site-packages/django/contrib/auth/models.py", line 3, in <module>
from django.contrib.auth.base_user import AbstractBaseUser, BaseUserManager
File "/Users/imac/Desktop/Project/Test/myenv/lib/python3.12/site-packages/django/contrib/auth/base_user.py", line 59, in <module>
class AbstractBaseUser(models.Model):
File "/Users/imac/Desktop/Project/Test/myenv/lib/python3.12/site-packages/django/db/models/base.py", line 143, in __new__
new_class.add_to_class("_meta", Options(meta, app_label))
File "/Users/imac/Desktop/Project/Test/myenv/lib/python3.12/site-packages/django/db/models/base.py", line 371, in add_to_class
value.contribute_to_class(cls, name)
File "/Users/imac/Desktop/Project/Test/myenv/lib/python3.12/site-packages/django/db/models/options.py", line 243, in contribute_to_class
self.db_table, connection.ops.max_name_length()
^^^^^^^^^^^^^^
File "/Users/imac/Desktop/Project/Test/myenv/lib/python3.12/site-packages/django/utils/connection.py", line 15, in __getattr__
return getattr(self._connections[self._alias], item)
~~~~~~~~~~~~~~~~~^^^^^^^^^^^^^
File "/Users/imac/Desktop/Project/Test/myenv/lib/python3.12/site-packages/django/utils/connection.py", line 62, in __getitem__
conn = self.create_connection(alias)
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
File "/Users/imac/Desktop/Project/Test/myenv/lib/python3.12/site-packages/django/db/utils.py", line 193, in create_connection
backend = load_backend(db["ENGINE"])
^^^^^^^^^^^^^^^^^^^^^^^^^^
File "/Users/imac/Desktop/Project/Test/myenv/lib/python3.12/site-packages/django/db/utils.py", line 126, in load_backend
raise ImproperlyConfigured(
django.core.exceptions.ImproperlyConfigured: 'sql_server.pyodbc' isn't an available database backend or couldn't be imported. Check the above exception. To use one of the built-in backends, use 'django.db.backends.XXX', where XXX is one of:
'mysql', 'oracle', 'postgresql', 'sqlite3'
На самом деле, какая у вас версия Django?
Кстати... почему ты используешь такую старую версию, ODBC Driver 13 for SQL Server
? Текущие выпуски — ODBC Driver 17 for SQL Server
и ODBC Driver 18 for SQL Server
. У вас может возникнуть меньше трудностей, если вы использовали Visual Studio Code с контейнерами разработки, поскольку контейнеры разработки сами по себе являются контейнерами Docker и, вероятно, будут очень похожи на среды, в которых вы развертываете свои приложения.
ModuleNotFoundError: нет модуля с именем «sql_server». Вышеупомянутое исключение было непосредственной причиной следующего исключения: Traceback (последний вызов): Файл «/Library/Frameworks/Python.framework/Versions/3.12/lib/python3.12 /threading.py", строка 1073, в _bootstrap_inner
Джанго 5.......
Проблема в установленной библиотеке. Версия Django <3 и конфигурация 'ENGINE': 'sql_server.pyodbc'
требуют библиотеки django-mssql-backend
. Однако при обновлении до современных версий Django (>3) используйте библиотеку mssql-django
с 'ENGINE': 'mssql'
в качестве конфигурации базы данных и "driver": "ODBC Driver 17 for SQL Server"
решение: pip install django-mssql-backend
также убедитесь, что ODBC Driver 17 for SQL Server
установлен. на Mac, беги brew install msodbcsql17 mssql-tools
Django > 3 django.db.utils.Error: ('01000', "[01000] [unixODBC][Диспетчер драйверов]Невозможно открыть библиотеку 'ODBC Driver 13 для SQL Server': файл не найден (0) (SQLDriverConnect) ")
это в Mac OS с Django 5
для django 5 используйте библиотеку mssql-django с «ENGINE»: «mssql» в качестве конфигурации базы данных и «драйвером»: «ODBC Driver 17 для SQL Server»
ошибка: self.connection = self.get_new_connection(conn_params) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Файл " /Users/imac/Desktop/Project/Test/myenv/lib/python3.12/site-packages/mssql/base.py", строка 368, в get_new_connection conn = Database.connect(connstr, **args ) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ django.db.utils.Error: ('01000', "[01000 ] [unixODBC][Диспетчер драйверов]Невозможно открыть библиотеку «Драйвер ODBC 17 для SQL Server»: файл не найден (0) (SQLDriverConnect)")
пожалуйста, проверьте, как установить драйверы odbc на Mac, на сайте Learn.microsoft.com/en-us/sql/connect/odbc/linux-mac/… или просто запустите brew install msodbcsql17 mssql-tools
Brew install msodbcsql17 mssql-tools Предупреждение: формула с именем «msodbcsql17» недоступна. ==> Поиск формул и бочек с одинаковыми именами... Ошибка: для msodbcsql17 не найдены формулы или бочки.
заварить кран microsoft/mssql-release github.com/Microsoft/homebrew-mssql-release заварить обновление
Файл "/Users/imac/Desktop/Project/Test/myenv/lib/python3.12/site-packages/mssql/base.py", строка 368, в get_new_connection conn = Database.connect(connstr, * *args) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ django.db.utils.OperationalError: ('HYT00', ' [HYT00] [Microsoft][Драйвер ODBC 17 для SQL Server]Тайм-аут входа истек (0) (SQLDriverConnect)')
используйте ip(127.0.0.1) вместо localhost
Ваша ошибка, похоже, не связана с какой-либо проблемой подключения к SQL Server. Похоже, это какая-то ошибка, связанная с моделью
auth.Group
и переводами. Пожалуйста, отредактируйте и предоставьте следующую информацию: 1) Настройки, связанные с приложением аутентификации и любой пользовательской моделью пользователя, если она у вас есть. 2) Настройки, связанные с интернационализацией/переводом. 3) ВашаINSTALLED_APPS
установка.