Sqlserver
 sql >> Base de Dados >  >> RDS >> Sqlserver

MSSQL2008 - Pyodbc - SQL anterior não era uma consulta


Apenas no caso de algum nômade da rede solitário encontrar esse problema, a solução do Torxed não funcionou para mim. Mas o seguinte funcionou para mim.

Eu estava chamando um SP que insere alguns valores em uma tabela e depois retorna alguns dados. Basta adicionar o seguinte ao SP:
SET NOCOUNT ON

Vai funcionar direitinho :)

O código Python:
    query = "exec dbo.get_process_id " + str(provider_id) + ", 0"
    cursor.execute(query)

    row = cursor.fetchone()
    process_id = row[0]

O SP:
USE [DBNAME]
GO
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
ALTER procedure [dbo].[GET_PROCESS_ID](
    @PROVIDER_ID INT,
    @PROCESS_ID INT OUTPUT
)
AS
BEGIN
    SET NOCOUNT ON
    INSERT INTO processes(provider_id) values(@PROVIDER_ID)
    SET @PROCESS_ID= SCOPE_IDENTITY()
    SELECT @PROCESS_ID AS PROCESS_ID
END