0

我有这样的SP

CREATE PROCEDURE dbo.pPersonGetIDByName
@Name nvarchar(50),
@ID int output
AS ...

和适当的 DataAccessor 方法

[ScalarSource(ScalarSourceType.OutputParameter)]
abstract int GetIDByName(string Name);

我将其理解为“调用存储过程,传递 Name 参数并返回我的第一个输出参数”。但是这个电话

id = pa.GetIDByName("testname");

返回我错误

过程或函数“pPersonGetIDByName”需要参数“@ID”,但未提供该参数。

据我在示例(OutputParameterTest())中看到的,它应该没问题。SQL Server 调用是正确的:

declare @p2 int
set @p2=default
exec pPersonGetIDByName @Name=N'testname',@ID=@p2 output
select @p2

怎么了?

4

1 回答 1

0

您是否尝试过传递参数名称:

[ScalarSource(ScalarSourceType.OutputParameter, "ID")]
abstract int GetIDByName(string Name);
于 2015-01-06T22:23:12.540 回答