A execução do processo armazenado do DotNet leva muito tempo, mas no SSMS é imediato

Eu tenho um processo armazenado no SQL Server 2000 que leva 3 parâmetros. Quando eu chamo o proc armazenado da DotNet usando SqlCommand.ExecuteReader (), leva cerca de 28 segundos.

Quando executo a mesma consulta diretamente no SSMS, ela retorna imediatamente.

Quando retiro a consulta do proc armazenado e a executo diretamente usando o DotNet, ela também retorna imediatamente.

Estes são os resultados de uma sessão do SQL Profiler

Rede interna do ponto do SP

Duração: 28030Lê: 2663365Escreve: 0

SP Inside SSMS

Duração: 450Lê: 23535Escreve: 65

Consulta diretamente dentro do Dot Net

Duração: 360Lê: 24865Escreve: 57

As seguintes coisas se destacam para mim:

As estatísticas para o SSMS e a consulta direta no Dot Net são muito semelhantesO Dot Net SP faz uma enorme quantidade de leituras, mas nenhuma gravaçãoOs outros dois fazem muito poucas leituras, mas algumas gravações

Qualquer ajuda seria apreciada.

Aqui está uma versão ligeiramente ignorada do SP:

Duvido que seja um problema no plano de consulta porque, mesmo que eu o execute repetidamente no DotNet, sempre obtenho os mesmos resultados.

Aqui está uma versão do SP que foi ligeiramente alterada devido a problemas de IP. Espero que ainda faça sentido:

SELECT 
t1.pkiOrderID,
t1.fkiBasketId,
t1.sOriginBasketCode,
t1.dtDateCreated,
t1.sOrderCode,
t1.fkiUserCde,
t1.fkiOrgCde,
t1.sApprovalPerson,
t1.dtDateApproved,
t1.sRequestNo,
t1.dtRequiredDate,
t1.Requestor,
t1.OnBehalfOf,
t1.OrderDesc,
t1.OrderTypeId,
t1.fkiAgentID,
t1.fkiAgentRegionID,
stat.iStatus,
count(oi.pkiOrderItemId) as OrderItems,
count(wf.fkiOrderId) as WorkflowCount,
t1.Currency_Id,
t1.ExchangeRate,
t1.ref_odr_idn,
t2.sOrderCode as ref_odr_cde,
t1.ref_rfq_nbr,
t1.ref_rfs_nbr,
t1.ref_doc_nbr,
t1.ref_rsn,
t1.ref_forip_cde,
t1.ref_fa_nbr,
t1.odr_sub_typ
FROM    tbl1 t1 INNER JOIN 
tbl1Status stat ON
t1.pkiOrderID = stat.fkiOrderID AND
stat.dtDateStatusChanged = (SELECT MAX(stat2.dtDateStatusChanged) 
FROM tbl1Status stat2
WHERE stat2.fkiOrderId = t1.pkiOrderID) LEFT OUTER JOIN 
tbl1Item oi ON
t1.pkiOrderID = oi.fkiOrderId LEFT OUTER JOIN
tbl1Workflows wf ON
t1.pkiOrderID = wf.fkiOrderId LEFT OUTER JOIN 
tbl1 t2 ON 
t1.ref_odr_idn = t2.pkiOrderID
WHERE (t1.fkiUserCde = 'x'
or t1.fkiUserCde in (select fkiUserCde from tbl1 where fkiOrgCde in 
(select sys_org_cde from tbl3 t3 where t3.sys_lnk_org_cde = '123')))
AND ((t1.fkiOrgCde = '123'
and ('123' not in (select sys_org_cde from tbl3 t3) 
or (t1.OrderTypeID <     1 or stat.iStatus IN (2,3,4,5,6,7))))
OR (t1.fkiOrgCde in (select sys_org_cde from tbl3 t3 where     t3.sys_lnk_org_cde = '123')
and t1.OrderTypeID = 1 
and stat.iStatus NOT IN (2,3,4,5,6,7)))           
          AND   t1.OrderTypeID = 2

        GROUP BY
            t1.pkiOrderID,
            t1.fkiBasketId,
            t1.sOriginBasketCode,
            t1.dtDateCreated,
            t1.sOrderCode,
            t1.fkiUserCde,
            t1.fkiOrgCde,
            t1.sApprovalPerson,
            t1.dtDateApproved,
            t1.sRequestNo,
            t1.dtRequiredDate,
            t1.Requestor,
            t1.OnBehalfOf,
            t1.OrderDesc,
            t1.OrderTypeId,
            t1.fkiAgentID,
            t1.fkiAgentRegionID,
            stat.iStatus,
            t1.Currency_Id,
            t1.ExchangeRate,
            t1.ref_odr_idn,
            t2.sOrderCode,
            t1.ref_rfq_nbr,
            t1.ref_rfs_nbr,
            t1.ref_doc_nbr,
            t1.ref_rsn,
            t1.ref_forip_cde,
            t1.ref_fa_nbr,
            t1.odr_sub_typ
        ORDER BY t1.dtDateCreated DESC

Desculpe a formatação. Eu lutei para torná-lo legível no fórum.

questionAnswers(2)

yourAnswerToTheQuestion