我试图弄清楚如何使用 Esqueleto 编写以下查询
SELECT COUNT("person"."id")
FROM "person"
WHERE (("person"."admin" = 't' OR "person"."vip" = 't') // 't' as in True
OR "person"."karma" >= 5000 AND "person"."hellbanned" = 'f')
这是我的模型的定义方式
Person
admin Bool
vip Bool
karma Int
hellbanned Bool
我已经设法得到了几乎所有东西,除了那COUNT
部分
select $
from $ \p -> do
where_
((p ^. PersonAdmin ==. val True) ||. (p ^. PersonVip ==. val True)
&&. (p ^. PersonKarma >=. val 5000) &&. (p ^. PersonHellbanned ==. val False))
return $ p ^. PersonId
我设法找到了一个countRows
函数,但是我还没有设法找到一种以类型检查的方式将这两者结合起来的方法。
我也不确定是否需要p ^.
where 子句的每个分支中的所有这些,或者是否可以以某种方式将它们折叠在一起?