使用sqlalchemy.engine.url.URL为mssql+pyodbc构建连接URL

时间:2022-11-25 10:23:16

The problem...

I am trying to connect to a MSSql server via SQLAlchemy. Here is my code with fake credentials (not my real credentials obviously).

我正在尝试通过SQLAlchemy连接到MSSql服务器。这是我的伪凭证代码(显然不是我的真实凭证)。

The code...

credentials = {
'username'  : 'SPOTTER_xyz_ACC',
'password'  : '123Goodbye2016!@#',
'host'      : 'MARYLQLT01',
'database'  : 'LRS_DUS',
'port'      : '1560'}

connect_url = sqlalchemy.engine.url.URL(
    'mssql+pyodbc',
    username=credentials['username'],
    password=credentials['password'],
    host=credentials['host'],
    port=credentials['port'],
    query=dict(service_name=credentials['database']))

engine = create_engine(connect_url)
connection=engine.connect()

And this is the .pyodbc error that I am getting.

这是。pyodbc错误。

(pyodbc.Error) ('IM002', '[IM002] [Microsoft][ODBC Driver Manager] Data source
name not found and no default driver specified (0) (SQLDriverConnect)')

Additional Details

But, here is what is weird... I if make a pyodbc connection and use Pandas.read_sql, then I can get data without an error. So I do not understand why I am getting a 'pyodbc' error????

但是,奇怪的是……我如果做一个pyodbc连接和使用熊猫。read_sql,这样我就可以不出错地获取数据。所以我不明白为什么会出现“pyodbc”错误?

connection=pyodbc.connect(\
                          'Driver={SQL Server}; \
                          Server=MARYLQLT01; \
                          Database=LRS_DUS; \
                          UID=SPOTTER_xyz_ACC; \
                          PWD=123Goodbye2016!@#')

stmt='select * from PD_SC_All'
df=pd.read_sql(stmt,connection)

And then I can see the dataframe.

然后我可以看到dataframe。

So, why am I getting the (pyodbc.Error) when I try to connect with SQLAlchemy?

那么,当我尝试连接SQLAlchemy时,为什么会得到(pyodbc.Error)呢?

System Information

Windows 7
SQLAlchemy: 1.1.11
pyodbc: 4.0.16

Python 3.6.1 |Anaconda custom (64-bit)| (default, May 11 2017, 13:25:24) [MSC v.1900 64 bit (AMD64)]
Type "copyright", "credits" or "license" for more information.

IPython 5.3.0 -- An enhanced Interactive Python.
?         -> Introduction and overview of IPython's features.
%quickref -> Quick reference.
help      -> Python's own help system.
object?   -> Details about 'object', use 'object??' for extra details.

1 个解决方案

#1


4  

As stated in the SQLAlchemy documentation, for mssql+pyodbc connections

如SQLAlchemy文档中所述,用于mssql+pyodbc连接

Hostname-based connections are not preferred, however are supported. The ODBC driver name must be explicitly specified:

不支持基于主机名的连接,但是支持。必须明确指定ODBC驱动程序名称:

engine = create_engine("mssql+pyodbc://scott:tiger@myhost:port/databasename?driver=SQL+Server+Native+Client+10.0")

For

credentials = {
    'username': 'scott',
    'password': 'tiger',
    'host': 'myhost',
    'database': 'databasename',
    'port': '1560'}

your statement

你的语句

connect_url = sqlalchemy.engine.url.URL(
    'mssql+pyodbc',
    username=credentials['username'],
    password=credentials['password'],
    host=credentials['host'],
    port=credentials['port'],
    query=dict(service_name=credentials['database']))

produces the connect_url

生产connect_url

mssql+pyodbc://scott:tiger@myhost:1560?service_name=databasename

What you really need is

你真正需要的是

connect_url = sqlalchemy.engine.url.URL(
    'mssql+pyodbc',
    username=credentials['username'],
    password=credentials['password'],
    host=credentials['host'],
    port=credentials['port'],
    database=credentials['database'],
    query=dict(driver='SQL+Server'))

which produces

生产

mssql+pyodbc://scott:tiger@myhost:1560/databasename?driver=SQL+Server

#1


4  

As stated in the SQLAlchemy documentation, for mssql+pyodbc connections

如SQLAlchemy文档中所述,用于mssql+pyodbc连接

Hostname-based connections are not preferred, however are supported. The ODBC driver name must be explicitly specified:

不支持基于主机名的连接,但是支持。必须明确指定ODBC驱动程序名称:

engine = create_engine("mssql+pyodbc://scott:tiger@myhost:port/databasename?driver=SQL+Server+Native+Client+10.0")

For

credentials = {
    'username': 'scott',
    'password': 'tiger',
    'host': 'myhost',
    'database': 'databasename',
    'port': '1560'}

your statement

你的语句

connect_url = sqlalchemy.engine.url.URL(
    'mssql+pyodbc',
    username=credentials['username'],
    password=credentials['password'],
    host=credentials['host'],
    port=credentials['port'],
    query=dict(service_name=credentials['database']))

produces the connect_url

生产connect_url

mssql+pyodbc://scott:tiger@myhost:1560?service_name=databasename

What you really need is

你真正需要的是

connect_url = sqlalchemy.engine.url.URL(
    'mssql+pyodbc',
    username=credentials['username'],
    password=credentials['password'],
    host=credentials['host'],
    port=credentials['port'],
    database=credentials['database'],
    query=dict(driver='SQL+Server'))

which produces

生产

mssql+pyodbc://scott:tiger@myhost:1560/databasename?driver=SQL+Server