Sql server 从存储过程返回值
使用SQL Server和ASP Classic从存储过程输出结果时遇到问题。如果我在程序中有一个简单的Sql server 从存储过程返回值,sql-server,tsql,stored-procedures,asp-classic,Sql Server,Tsql,Stored Procedures,Asp Classic,使用SQL Server和ASP Classic从存储过程输出结果时遇到问题。如果我在程序中有一个简单的选择,它可以正常工作。但是使用这里显示的代码,我得到了一个错误 我在SQL Server中有以下存储过程: ALTER PROCEDURE [dbo].[Sp_Teste] @data varchar(8) AS BEGIN --DROP TABLE IF EXISTS #TempSubs DECLARE @TempSubs TABLE
选择,它可以正常工作。但是使用这里显示的代码,我得到了一个错误
我在SQL Server中有以下存储过程:
ALTER PROCEDURE [dbo].[Sp_Teste]
@data varchar(8)
AS
BEGIN
--DROP TABLE IF EXISTS #TempSubs
DECLARE @TempSubs TABLE
(
PedidoID Int,
NumeroPedido Varchar(20),
SubstituidoPor Varchar(8000)
)
INSERT INTO @TempSubs (PedidoID, NumeroPedido, SubstituidoPor)
SELECT
P.ID, P.NumeroPedido,
STRING_AGG(CAST(IPA.Quantidade AS varchar(5)) + 'X ' + Pd.Nome, ', ') + ' por ' + STRING_AGG(CAST(IPA.Quantidade AS varchar(5)) + 'X ' + Pd2.Nome, ', ') AS SubstituidoPor
FROM
Pedidos P, Clientes C, Produtos Pd, ItensPedidosAjustado IPA, Produtos Pd2
WHERE
P.ID = IPA.PedidoId
AND P.ClienteId = C.ID
AND Pd.ID = IPA.ProdutoId
AND Faltante = 1
AND CONVERT(Date, P.DataPedido, 103) = CONVERT(Date, @data, 103)
AND (IPA.ProdutoSubstituidoId <> 0)
AND Pd2.ID = IPA.ProdutoSubstituidoId
AND ((P.StatusPedido <> 'Pause' AND P.StatusPedido <> 'PULOU ENTREGA' AND P.StatusPedido <> 'Pedido Cancelado') OR P.StatusPedido IS NULL)
GROUP BY
P.ID, P.NumeroPedido, IPA.ProdutoSubstituidoId
SELECT
(SELECT STRING_AGG(Indisponibilidade, ', ')
FROM @TempIndis A
WHERE A.PedidoID = P.ID) AS Indisponibilidade,
(SELECT STRING_AGG(SubstituidoPor, ', ')
FROM @TempSubs A
WHERE A.PedidoID = P.ID) AS Substituicao
FROM
Pedidos P, Clientes C, ItensPedidosAjustado IPA
WHERE
P.ID = IPA.PedidoId
AND P.ClienteId = C.ID
AND Faltante = 1
AND CONVERT(Date, P.DataPedido, 103) = CONVERT(Date, @data, 103)
AND ((P.StatusPedido <> 'Pause' AND P.StatusPedido <> 'PULOU ENTREGA' AND P.StatusPedido <> 'Pedido Cancelado') OR P.StatusPedido IS NULL)
AND P.PedidoCancelado = 0
GROUP BY
P.ID, P.NumeroPedido, C.Nome, C.Email, P.TipoAssinatura
ORDER BY
numeropedido
END
我得到这个错误:
ADODB.记录集错误“800a0e78”
对象关闭时不允许操作。
/ATendmento/testestoreprocedure.asp,第18行
默认情况下,SQL Server在INSERT
语句之后返回(rowcount)消息,ADO classic将返回一个关闭/空的结果集。在SELECT
查询结果可用之前,必须通过调用NextRecordset
方法来使用这些数据
为了避免额外的编码,请养成在存储过程中指定的习惯,以抑制那些不需要的结果。将其添加到程序代码的开头以避免错误。您不需要先打开连接吗?请不要使用,
加入suntax,它已被弃用多年。请注意:您不应该在存储过程中使用sp_u
前缀。微软已经这样做了,而且你确实有可能在将来的某个时候发生名称冲突。最好只是简单地避免使用sp.
并使用其他东西作为前缀,或者根本不使用前缀!这个问题已经被问得死去活来了,说真的,我们为什么需要这样做呢?@user692942,我用谷歌做了一个粗略的搜索,我没有找到前两个结果的答案,这些结果在_PROC
消息中发出了done_,这个问题也可以由客户端代码处理。完全同意在微软发布了糟糕的ADO经典API 20年后,这个问题变得普遍起来。
db_conn = "Provider=SQLNCLI11;Server=xxxx;Database=BaseGaia;Uid=sqlserver;Pwd=xxxxx;"
set conn = server.createobject("adodb.connection")
set Cmd = Server.CreateObject("ADODB.Command")
'-------------------------------------------------------
conn.open (db_conn)
'-------------------------------------------------------
set rs = Server.CreateObject("ADODB.RecordSet")
sSQL = "EXEC Sp_Teste @data = '20210301'"
set rs = conn.execute (sSQL)
response.write rs.eof