2

我正在使用来自http://www.ironpython.info/index.php/Accessing_SQL_Server的源代码使用 python 查询 MS SQL :

import clr
clr.AddReference('System.Data')
from System.Data import *

TheConnection = SqlClient.SqlConnection
("server=yourserver;database=News;uid=sa;password=password;timeout=0")
TheConnection.Open()

MyAction = SqlClient.SqlCommand("Select Headline from News", TheConnection)
MyReader = MyAction.ExecuteReader()

while MyReader.Read():
    print MyReader[0]

MyReader.Close()
TheConnection.Close()

我刚刚添加timeout=0,但我仍然得到:

EnvironmentError: System.Data.SqlClient.SqlException (0x80131904): Timeout 
expired.  The timeout period elapsed prior to completion of the operation 
or the server is not responding.

我试过了timeout=1000000,但仍然得到同样的错误。

如果我使用 MSSQL 客户端在同一台机器上运行相同的 SQL,那就完全没问题了。你知道如何避免这个超时异常吗?

4

1 回答 1

0

尝试增加 SqlCommand 上的 CommandTimeout 属性,如下所述: https ://msdn.microsoft.com/en-us/library/system.data.sqlclient.sqlcommand.commandtimeout(v=vs.110).aspx

连接字符串中的超时值仅控制与数据库的初始连接的超时。如果您的 SQL 查询需要很长时间才能执行,那么这将无济于事,因此您需要改用 CommandTimeout。

于 2015-12-11T00:16:00.007 回答