Ecto Changesets:数据处理与关联操作全解析
1. 约束与验证的区别
在数据处理过程中,约束(constraints)和验证(validations)的行为有所不同。Ecto 会对给定的变更集(changeset)运行所有验证,即便其中一个验证失败,其余的验证仍会继续执行。这样做的好处是,能一次性向用户展示所有错误值,而非逐个显示,提升了用户体验。
然而,约束的作用类似于断路器。若存在多个约束,其中一个失败,其余约束将不再进行检查。同样,若任何验证失败,约束也不会被检查。若变更集验证失败,Ecto 不会尝试将其发送到数据库。
在某些情况下,这种行为可能会带来麻烦。例如,在用户注册表单中,数据库的用户名列有唯一索引,确保每个用户的用户名唯一。我们希望在变更集中使用 unique_constraint ,以便用户输入已被占用的用户名时能收到错误消息。但只有所有验证通过后,才会检查该约束。若用户在表单的其他部分出错,他们会先看到验证失败的错误消息。当他们纠正所有错误后,才会发现用户名不可用,这会给用户带来糟糕的体验。
为解决此问题,Ecto 提供了 unsafe_validate_unique 函数。它结合了验证和约束的特点,像约束一样检查数据库中值是否已存在,但会与其他验证一起评估,使用户能同时看到所有验证错误。不过,该函数名中的 “unsafe” 表明不能完全依赖它,因为在函数运行和 Ecto 尝试插入记录之间,仍有可能有人插入重复值。但它能提前告知用户需要选择新的用户名。虽然 unique_constraint 所防范的竞态条件很少出现,但为以防万一,还是应该
超级会员免费看
订阅专栏 解锁全文
60

被折叠的 条评论
为什么被折叠?



