域名 AXUM.RS 将于 2025 年 10 月到期。我们无意再对其进行续费,如果你有意接续这个域名,请与我们取得联系。
  • AXUM.RS 现仅需人民币 3000 元(大写:叁仟元整。接受适度议价
  • 按照行业规则,AXUM.RS 到期后,大概率会进入长时间的赎回期,该期间内,如果你想拥有该域名,将要付出高额的费用
  • 我们已启用 AXUM.EU.ORG 域名,并将持续运营
  • 仅接受微信或支付宝交易
如果你对 AXUM.RS 有兴趣,请和我们进行联系:

sqlx优雅地实现IN查询

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

需求

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

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

错误的实现

// 伪代码

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()方法,它能更优雅、可靠地实现这一需求。

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

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