PYODBC游标更新SQL数据库中的表

时间:2016-06-01 14:38:45

标签: pandas pyodbc

以下是我的数据框的一小部分示例

    In [121]: df
    Out[121]:
  TXN_KEY SEND_AGENT  PAY_AGENT
0  13273870  ANO080012  API352676
1  13274676  AUK359401  API352676
2  13274871  ACL000105  API352676
3  13275398  AED420319  API352676
4  13278566  ARA030210  API352676
5  13278955  AYM003098  API352676
6  13280334  AJ5020114  API352676
7  13280512  A11171047  API352676
8  13281278  AOG010045  API352676
9  13282118  AMX334165  API352676

我正在尝试使用pyodbc中的游标来更新sql server数据库中的表“result”和数据帧值

cursor.execute("Update result set Pay_Agent = df['PAY_AGENT'][0] where Send_Agent = df['SEND_AGENT'][0]")

我得到以下错误:

 ProgrammingError: ('42000', "[42000] [Microsoft][SQL Server Native Client 11.0][SQL Server]Incorrect syntax near ''PAY_AGENT''. (102) (SQLExecDirectW)")

但我确保数据类型在我的更新语句中正确匹配。

In [126]: type(df['PAY_AGENT'][0])
Out[126]: str

In [127]: type(df['SEND_AGENT'][0])
Out[127]: str

任何见解都表示赞赏。

1 个答案:

答案 0 :(得分:2)

您必须使用参数正确格式化查询:

cursor.execute("Update result set Pay_Agent = ? where Send_Agent = ?", (df['PAY_AGENT'][0], df['SEND_AGENT'][0]))

以这种方式使用绑定参数对于您使用的任何语言都很重要,以避免可能的SQL注入。祝你好运!