繁体   English   中英

如何使用pyodbc获取SQL Server存储过程返回的行集?

[英]How to get a SQL Server stored procedure returned rowset using pyodbc?

我的问题与stackoverflow / 9915788密切相关。

我正在使用pyodbc将数据上传到外部SQL数据库,为此我使用该数据库的存储过程。 此过程返回两件事:

  • 一个行集(如果过程正常或文本“失败”后面包含文本“成功”的单行,如果失败则后面跟着任何可用的原因)
  • 整数值(0表示成功,-1表示失败)

我设法使用上面链接中描述的方法读出整数值,但我也想读出行集,因为我想在出现任何错误时获取更多信息。

任何想法如何做到这一点? 我不是SQL专家,但根据我的理解,行集应该是一个“像游标一样”的对象,因为它应该可以循环该行; 但是如何在select语句中得到它?

这是我得到整数值的方法:

def CallStoredProc(conn, procName, *args):
    sql = """SET NOCOUNT ON;
            DECLARE @ret int
            EXEC @ret = %s %s
            SELECT @ret""" % (procName, ','.join(['?'] * len(args)))
    return conn.execute(sql, args).fetchall()

但我不知道如何获得行,这也应该在某处可用..

对于SQL Server中的以下存储过程

CREATE PROCEDURE [dbo].[IsItGord] 
    @p1 varchar(50) = 'everybody'
AS
BEGIN
    DECLARE @retval int;
    SET NOCOUNT ON;
    IF @p1 = 'Gord'
    BEGIN
        SET @retval = 0;
        SELECT 'Success' AS response;
    END
    ELSE
    BEGIN
        SET @retval = -1;
        SELECT 'Fail - ' + @p1 + ' is not Gord.' AS response;
    END
    RETURN @retval;
END

以下pyodbc代码

cnxn = pyodbc.connect(connStr)
sql = """\
DECLARE @return_value int;
EXEC    @return_value = [dbo].[IsItGord] ?;
SELECT  'Return Value' = @return_value;
"""
crsr = cnxn.execute(sql, ("Gord"))
data = crsr.fetchall()
print(data)
crsr.nextset()
data = crsr.fetchall()
print(data)

版画

[('Success', )]
[(0, )]

如果我将.execute()更改为

crsr = cnxn.execute(sql, ("Fred"))

它打印

[('Fail - Fred is not Gord.', )]
[(-1, )]

在SQL Server中执行存储过程之前,始终使用:set nocount ON。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM