我正在使用 DapperDynamicParameters
将参数字典从我的 .NET Core 应用程序发送到 SQL Server,但出现错误:
未提供参数 @cityName1
但是当我跟踪查询时,我可以看到它存在。
这是代码:
填写字典:
Dictionary<string, object> cities = new Dictionary<string, object>();
cities.Add("@cityName1", "New-York");
cities.Add("@cityId1", 123);
对 Dapper 的调用:
DynamicParameters dbArgs = new DynamicParameters();
foreach (var pair in cities)
{
dbArgs.Add(pair.Key, pair.Value);
}
return await connection.QueryAsync<Provider>(SQL_GET_LINKS_BY_CITIES, dbArgs);
存储过程:
CREATE PROCEDURE [dbo].[hp_GetLinksByCities]
(@cityName1 NVARCHAR(25),
@cityId1 INT)
AS
BEGIN
-- code
END
分析器的跟踪:
exec sp_executesql N'[dbo].[hp_GetLinksByCities]',N'@cityName1 nvarchar(4000),@cityId1 int',@cityName1=N'Marseille',@cityId1=1970
错误
原文(法文):
La procédure ou fonction 'hp_GetLinksByCities' 参加 le paramètre '@cityName1',qui n'a pas étéfourni。
翻译成英文:
存储过程或函数“hp_GetLinksByCities”需要一个未提供的“@cityName1”参数
当我在 SSMS 中执行这段代码时,我得到了同样的错误,但是使用这种语法,它工作正常:
exec [dbo].[hp_sp_GetDirectoryPageLinksByCities] @cityName1=N'Marseille',@cityId1=1970
通常,Dapper 以这种方式发送订单,并且运行良好。为什么这一次的表现有所不同?
我不知道出了什么问题...我需要使用DynamicParameter
不同的方法吗?
谢谢你的帮助 :)