sqlx优雅地实现IN查询

在日常开发中,IN 查询是非常常见的需求,你会怎么来处理呢?借助 sqlx 的QueryBuilder 可以方便地实现。

SELECT * FROM member WHERE id IN(1,2,3,4);

注意,IN(???) 条件不是固定的,例中 IN(1,2,3,4) 只是举例,以便理解需求。

错误的实现

  • 将参数合并为字符串
  • 将合并后的字符串绑定到 sqlx 中

这种方式不会报错,甚至能工作的很好。但也可能遇到未知的BUG。

sqlx 的 QueryBuilder 提供了 push_tuples()方法,它能更优雅、可靠地实现这一需求。

正确的实现

本章代码位于07/in分支。

要查看完整内容,请先登录