使用 Python 通过 Windows 身份验证连接到 MS SQL Server?

本教程将介绍使用 Python 通过 Windows 身份验证连接到 MS SQL Server?的处理方法,这篇教程是从别的地方看到的,然后加了一些国外程序员的疑问与解答,希望能对你有所帮助,好了,下面开始学习吧。

使用 Python 通过 Windows 身份验证连接到 MS SQL Server? 教程 第1张

问题描述

怎么使用 Windows 身份验证将 MS SQL Server 与 pyodbc 库连接?

我可以通过 MS Access 和 SQL Server Management Studio 进行连接,但无法获得适用于 Python 的有效连接 ODBC 字符串.

这是我尝试过的(也没有 'Trusted_Connection=yes'):

pyodbc.connect('Trusted_Connection=yes',
driver='{SQL Server}', server='[system_name]',
database='[databasename]')

pyodbc.connect('Trusted_Connection=yes', uid='me',
driver='{SQL Server}', server='localhost',
database='[databasename]')

pyodbc.connect('Trusted_Connection=yes',
driver='{SQL Server}', server='localhost',
uid='me', pwd='[windows_pass]', database='[database_name]')

pyodbc.connect('Trusted_Connection=yes',
driver='{SQL Server}', server='localhost',
database='[server_name][database_name]')

pyodbc.connect('Trusted_Connection=yes',
driver='{SQL Server}', server='localhost',
database='[server_name][database_name]')

pyodbc.connect('Trusted_Connection=yes',
driver='{SQL Server}',
database='[server_name][database_name]')

推荐答案

您可以将连接字符串指定为一个使用分号(;)作为参数分隔符的长字符串.

工作示例:

import pyodbc
cnxn = pyodbc.connect(r'Driver=SQL Server;Server=.SQLEXPRESS;Database=myDB;Trusted_Connection=yes;')
cursor = cnxn.cursor()
cursor.execute("SELECT LastName FROM myContacts")
while 1:
 row = cursor.fetchone()
 if not row:
  break
 print(row.LastName)
cnxn.close()

对于具有大量参数的连接字符串,以下内容将完成相同的事情,但以更易读的方式:

conn_str = (
 r'Driver=SQL Server;'
 r'Server=.SQLEXPRESS;'
 r'Database=myDB;'
 r'Trusted_Connection=yes;'
 )
cnxn = pyodbc.connect(conn_str)

(请注意,各个字符串组件之间没有逗号.)

好了关于使用 Python 通过 Windows 身份验证连接到 MS SQL Server?的教程就到这里就结束了,希望趣模板源码网找到的这篇技术文章能帮助到大家,更多技术教程可以在站内搜索。