sqlx优雅地实现IN查询

需求

假设有一个需求,需要返回一系列指定ID的会员信息的列表。对应的 SQL 语句大概这样:

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

错误的实现

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

let ids_str:Vec<String> = ids.iter().map(|id|id.to_string()).collect(); 
let ids_arg:String = ids_str.join(",");
let list:Vec<Member> = sqlx::query_as("SELECT * FROM member WHERE id IN(?)").bind(&ids_arg).fetch_all(conn).await.unwrap();

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

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

正确的实现

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