使用 Dapper ORM 和 IEnumerable 值通过 IN 子句查询数据库
使用 IN 子句查询数据库是一种常见操作,当使用Dapper ORM,当 IN 子句的值来自业务时,有一种有效的方法来编写这些查询逻辑。
Dapper 允许您直接将 IEnumerable 值作为参数传递,而不是手动将值连接成逗号分隔的字符串。例如,给定查询:
SELECT * FROM SomeTable WHERE id IN (commaSeparatedListOfIDs)
其中 commaSeparatedListOfIDs 是整数的 IEnumerable,您可以使用 Dapper 构造查询,如下所示:
string sql = "SELECT * FROM SomeTable WHERE id IN @ids"; var results = conn.Query(sql, new { ids = new[] { 1, 2, 3, 4, 5 }});
Dapper 将自动生成适当的 SQL来自 IN 子句并绑定 ids 参数的值。请注意,如果您使用 PostgreSQL,则需要稍微不同的方法。详情请参阅提供的答案。
以上是如何有效地将 Dapper 的 IN 子句与 IEnumerable 值结合使用?的详细内容。更多信息请关注PHP中文网其他相关文章!