7

我通常使用 Postgres 来满足我对 Django 的数据库需求,但我最近开始在一家在 Windows 环境中使用 MSSQL 的公司工作。长话短说,我不得不重写 settings.py 中的数据库属性。不幸的是,我不知道如何使用 Pyodbc 连接到 SQL Server,而且他们正在运行 Python 3.x,所以我不能使用 Django-Pyodbc。在尝试运行它时,我得到一个:“找不到数据源名称并且没有指定默认驱动程序 (0) (SQLDriverConnect)')”

这是我当前的数据库配置。我可能做错了什么,但很难找到资源,因为大多数 Django+Sql Server 结果要么使用 FreeTDS 要么使用 Django-Pyodbc(两者都不是选项)。

'default': {
    'ENGINE': 'sql_server.pyodbc',
    'NAME': 'db_name_on_server',
    'USER': 'my_acct',
    'PASSWORD': 'nope',
    'HOST': 'x.x.x.x',
    'PORT': '1433',
    'OPTIONS': {  # Options are not edited
        'driver': 'SQL Server',  # What it displays as on odbc admin   
        'dsn': 'System DSN',  # What it displays as on odbc admin
        'use_legacy_datetime': False
    }
4

3 回答 3

7

老问题,但它可能会帮助某人。这些是我在 Windows 中用于连接 SQL Server 的设置。正如@flipperpa 所说,我也使用django-pyodbc-azure

pyodbc==3.0.10
django-pyodbc-azure==1.10.0.1

但是,pip 将下载的 pyodbc 对我不起作用。正如此答案中所建议的,请访问此站点http://www.lfd.uci.edu/~gohlke/pythonlibs/#pyodbc并根据您安装的 Python 3.5 版本下载:

  • pyodbc‑3.0.10‑cp35‑none‑win32.whl如果您有 32 位 Python 3.5 安装
  • pyodbc‑3.0.10‑cp35‑none‑win_amd64.whl如果您有 64 位 Python 3.5 安装

然后使用这些设置进行连接:

'default': {
 'ENGINE': 'sql_server.pyodbc',
 'HOST': "localhost",
 'USER': "--user name--",
 'PASSWORD': "--password--",
 'NAME': "--database name--",
 'PORT': 1433,
 'OPTIONS': {
      'driver' : 'SQL Server Native Client 11.0',
      'MARS_Connection' : True,
      'driver_supports_utf8' : True,
 },
}

对于任何使用 linux 的人,MS 现在已经发布了 SQL server 的官方 odbc 驱动程序,并且正式(如果有点默契)支持 django-pyodbc-azure 项目。我强烈建议使用它以及 FreeTDS 上的本机 linux SQL Server ODBC 驱动程序。

于 2016-10-18T17:41:07.727 回答
2

我在以下堆栈中获得了最好的运气,而且我们是一家专门的 Python 3 商店:

  • 免费TDS 0.95
  • pyodbc 3.0.10
  • django-pyodbc-azure 1.8.3(假设 Django 1.8+)

假设您有odbc.iniodbcinst.inifreetds.conf全部平方,这里有一个对我有用的设置示例。其中一些取决于您是否使用 SQL Server 2008+:

DATABASES = {
    'default': {
        'ENGINE': 'sql_server.pyodbc',
        'HOST': 'yourserver.com',
        'PORT': '1433',
        'NAME': 'your_db',
        'USER': 'your_user',
        'PASSWORD': 'your_pw',
        'AUTOCOMMIT': True,
        'OPTIONS': {
            'driver': 'FreeTDS',
            'unicode_results': True,
            'host_is_server': True,
            'extra_params': 'tds_version=7.2;',
        },
    },
}

如果您运行的是 SQL Server 2005 或更低版本,您还需要包括在内'use_legacy_datetime': True,,否则,它将使用新的 SQL Server 2008+ 日期字段。如果您使用的是过时的驱动程序,它也会自动设置为 true。祝你好运!

于 2015-09-24T22:57:08.657 回答
0

同时有用于 MSSQL 支持的django-mssql-backend,这就是我的设置的样子(Django 3.0,django-mssql-backend 2.8.1)

DATABASES = {
    'default': {
        'ENGINE': 'sql_server.pyodbc',
        'NAME': os.getenv('DB_NAME'),
        'USER': os.getenv('DB_USER'),
        'PASSWORD': os.getenv('DB_PASSWORD'),
        'HOST': os.getenv('DB_HOST'),
        'PORT': os.getenv('DB_PORT'),
        'TEST': {
            'NAME': os.getenv('DB_NAME'),
        },
        'OPTIONS': {
            'driver': 'ODBC Driver 17 for SQL Server',
            'extra_params': 'MARS_Connection=Yes'
        },
    }
}
于 2020-11-03T11:46:10.680 回答