我有一个必须使用的存储过程。SQL开发人员给出的结果看起来像一个表。但当我试图用Pyodbc获得结果时,我只得到:
错误:没有结果。以前的SQL不是查询。
我认为这可能是产生结果的方式,因为它使用了select。我不知道如何得到输出。我尝试了一些来自指南和SO问题的其他想法,但我运气不佳。
SP看起来像这样:
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
ALTER PROCEDURE schema.spname
AS
BEGIN
SET NOCOUNT ON
SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED
BEGIN TRY
DECLARE @NewLogID BIGINT
DECLARE @recs INT = 0
DECLARE @Process VARCHAR(200) = OBJECT_NAME(@@PROCID)
-- Log the Process
EXEC anrm.WriteANRMLog @ProcessName = @Process,@ReturnLogID=@NewLogID OUTPUT
SELECT receipt_id, order_id, user_id
FROM tableA
WHERE A.Qty>0
AND datesent IS NULL
--EXEC schema.othertable @RecordCount = @recs,@logid= @NewLogID, @ReturnLogID=@NewLogID OUTPUT
PRINT @Process + ' - Completed'
END TRY
BEGIN CATCH
EXEC anrm.PrintError
--EXEC anrm.LogNRMError
END CATCH
END
最近,我正试图得到这样的结果。
try:
cnxn = pyodbc.connect('DRIVER={ODBC Driver 17 for SQL Server};SERVER=' +
server+';DATABASE='+database+';UID='+username+';PWD=' + password)
cnxn.autocommit = True
cursor = cnxn.cursor()
cursor.execute("SET NOCOUNT ON; exec schema.spname")
row = cursor.fetchone()
while row:
print(str(row[0]) + " " + str(row[1]))
row = cursor.fetchone()
cursor.close()
del cursor
cnxn.close()
except Exception as e:
print("Error: %s" % e)
您能修改SP吗?如果是这样,请让它将结果插入临时表中,而不是在SP中运行select。然后在python 中
cursor.execute("exec schema.spname")
cursor.execute("select * from #my_temp_table")
cursor.execute("drop table #my_temp_table")
这对你有用吗?
# SQL Server format
cursor.execute("exec sp_dosomething(123, 'abc')")
# ODBC format
cursor.execute("{call sp_dosomething(123, 'abc')}")