Python:使用参数执行存储过程

loc*_*ost 7 python sql-server stored-procedures

我正在编写一个 Python 脚本,它将记录从存储过程写入文本文件。我在使用参数执行存储过程时遇到问题。

我不确定我可以采取什么不同的方法来使用这两个参数执行此存储过程。您可以在下面看到我遇到的错误。

任何见解将不胜感激。

这是我的代码

# Import Python ODBC module
import pyodbc

# Create connection
cnxn = pyodbc.connect(driver="{SQL Server}",server="<server>",database="<database>",uid="<username>",pwd="<password>")
cursor = cnxn.cursor()

# Execute stored procedure
storedProc = "exec database..stored_procedure('param1', 'param2')"

# Loop through records
for irow in cursor.execute(storedProc):

    # Create a new text file for each ID
    myfile = open('c:/Path/file_' + str(irow[0]) + '_' + irow[1] + '.txt', 'w')

    # Write retrieved records to text file
    myfile.write(irow[2])

    # Close the file
    myfile.close()
Run Code Online (Sandbox Code Playgroud)

这是错误

Traceback (most recent call lst):
File "C:\Path\script.py", line 12, in <module>
  for irow in cursor.execute(storedProc):
      pyodbc.ProgrammingError: ('42000', "[4200] [Microsoft][ODBC SQL Server Driver][SQL Server]Incorrect syntax near 'param1'. <102> <SQLExecDirectW>">
Run Code Online (Sandbox Code Playgroud)

loc*_*ost 4

我能够通过从查询字符串中删除括号来修复语法错误。

# Execute stored procedure
storedProc = "exec database..stored_procedure('param1', 'param2')"
Run Code Online (Sandbox Code Playgroud)

应该

# Execute stored procedure
storedProc = "exec database..stored_procedure 'param1','param2'"
Run Code Online (Sandbox Code Playgroud)