Dapper.NET 列表扩展
示例
数据库查询中的一个常见情况IN(...)是在运行时在此处生成列表。大多数RDBMS对此没有一个很好的隐喻-并且没有通用的跨RDBMS解决方案。相反,dapper提供了一些温和的自动命令扩展。所需要的只是提供的参数值IEnumerable。涉及的命令@foo将扩展为(@foo0,@foo1,@foo2,@foo3)(针对4个项目的序列)。最常见的用法是IN:
int[] orderIds = ...
var orders = connection.Query<Order>(@"
select *
from Orders
where Id in @orderIds", new { orderIds });然后,它会自动扩展以针对多行获取发出适当的SQL:
select * from Orders where Id in (@orderIds0, @orderIds1, @orderIds2, @orderIds3)
加上参数@orderIds0等作为从错误中获取的值。请注意,SQL最初实际上是无效的,这是有意为之的,以确保不会错误地使用此功能。此功能还可以与SQLServer中的OPTIMIZEFOR/UNKNOWNquery-hint一起正常使用;如果您使用:
option (optimize for
(@orderIds unknown))它将正确扩展为:
option (optimize for
(@orderIds0 unknown, @orderIds1 unknown, @orderIds2 unknown, @orderIds3 unknown))
热门推荐
10 女神结婚快乐祝福语简短
11 孩子懂事生日祝福语简短
12 考试祝福语老师评语简短
13 朋友隔离结束祝福语简短
14 新婚过年祝福语大全简短
15 过年祝福语简短又温馨
16 岗位考试顺利祝福语简短
17 开学新人祝福语简短英语
18 寒露祝福语毕业寄语简短