dynamicparams java,Dapper AddDynamicParams for IN statement with“dynamic”参数名称

I have simple SQL string like this:

"SELECT * FROM Office WHERE OfficeId IN @Ids"

The thing is that the @Ids name is entered in an editor so it could be whatever, and my problem is that if I want to pass in, say an array of integers, it only works with Dapper if I use:

var values = new DynamicParameters();

values.AddDynamicParams(new { Ids = new[] { 100, 101 } });

But this requires me to KNOW that the parameter name is "Ids" and that's not the case in my scenario.

I can set a "dynamic parameter" in Dapper with a "dynamic" name like this:

var values = new DynamicParameters();

values.Add("Ids", new[] { 100, 101 });

But then Dapper doesn't construct the "IN (....)" SQL with separate parameters for each value.

Is there a way to construct the dynamic object passed in to "AddDynamicParams" but setting the member name and value without knowing the name beforehand?

I could modify the Dapper source to work for my scenario, but if anyone know of a simpler and elegant solution to this I would be greatful!

Best regards

Jens

解决方案

I have just submitted a fix to the repository that allows any of the following to work correctly:

by object (this worked previously):

values.AddDynamicParams(new { ids = list });

or, by single name:

values.Add("ids", list);

or, as a dictionary:

var args = new Dictionary();

args.Add("ids", list);

values.AddDynamicParams(args);

I have not yet deployed to NuGet. Let me know if this is a problem.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值