- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
考虑像这样的存储库/DAO 方法,效果很好:
def countReports(customerId: Long, createdSince: ZonedDateTime) =
DB.withConnection {
implicit c =>
SQL"""SELECT COUNT(*)
FROM report
WHERE customer_id = $customerId
AND created >= $createdSince
""".as(scalar[Int].single)
}
但是如果方法是用可选参数定义的呢:
def countReports(customerId: Option[Long], createdSince: Option[ZonedDateTime])
要点是,如果存在任一可选参数,则使用它来过滤结果(如上所示),否则(如果它是 None
),只需省略相应的 WHERE 条件。
使用可选的 WHERE 条件编写此方法的最简单方法是什么?作为 Anorm 新手,我一直在努力寻找这样的示例,但我想肯定有一些明智的做法(即,不为存在/缺失参数的每个组合复制 SQL)。
请注意,当在 Anorm SQL
调用中使用时,java.time.ZonedDateTime
实例会完美且自动地映射到 Postgres timestamptz
。 (尝试将 WHERE 条件提取为字符串,在 SQL
之外,使用普通字符串插值创建的字符串无效;toString
生成数据库无法理解的表示。)
Play 2.4.4
最佳答案
一种方法是设置过滤子句,例如
val customerClause =
if (customerId.isEmpty) ""
else " and customer_id={customerId}"
然后将这些代入你的SQL:
SQL(s"""
select count(*)
from report
where true
$customerClause
$createdClause
""")
.on('customerId -> customerId,
'createdSince -> createdSince)
.as(scalar[Int].singleOpt).getOrElse(0)
我认为使用 {variable}
而不是 $variable
更可取,因为它可以降低 SQL 注入(inject)攻击的风险,在这种情况下,有人可能会使用恶意字符串调用您的方法。 Anorm 不介意您是否有未在 SQL 中引用的其他符号(即如果子句字符串为空)。最后,根据数据库(?),计数可能不返回任何行,因此我使用 singleOpt 而不是 single。
我很好奇您还收到了什么其他答案。
编辑:异常插值(即 SQL"...",一种超越 Scala 的 s"..."、f"..."和 raw"..."的插值实现)was introduced允许使用 $variable
等同于 {variable}
with .on
。从 Play 2.4 开始,Scala 和 Anorm 插值可以混合使用 $
用于 Anorm(SQL 参数/变量)和 #$
用于 Scala(纯字符串)。事实上,只要 Scala 内插字符串不包含对 SQL 参数的引用,它就可以正常工作。在 2.4.4 中,我发现在使用 Anorm 插值时在 Scala 插值字符串中使用变量的唯一方法是:
val limitClause = if (nameFilter="") "" else s"where name>'$nameFilter'"
SQL"select * from tab #$limitClause order by name"
但这很容易受到 SQL 注入(inject)的攻击(例如像 it's
这样的字符串会导致运行时语法异常)。因此,对于内插字符串中的变量,似乎有必要使用“传统”.on
方法,仅使用 Scala 插值:
val limitClause = if (nameFilter="") "" else "where name>{nameFilter}"
SQL(s"select * from tab $limitClause order by name").on('limitClause -> limitClause)
也许将来可以扩展 Anorm 插值以解析变量的插值字符串?
Edit2:我发现有些表中可能包含或可能不包含在查询中的属性数量不时发生变化。对于这些情况,我定义了一个上下文类,例如客户上下文
。在这个案例类中,有 lazy val
用于影响 sql 的不同子句。 sql 方法的调用者必须提供 CustomerContext
,然后 sql 将包含 ${context.createdClause}
等内容。这有助于提供一致性,因为我最终在其他地方使用上下文(例如分页的总记录数等)。
关于scala - Anorm:WHERE条件,有条件的,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34078955/
如何在 2014-10-04 - 2014-10-30 仅工作日和 08.00 - 20.00 之间随机更新日期列? 2014-10-04 - 2014-10-30 random working-da
我有一个二维 (3x7) 数组,我想转换为一维数组,以便我提供的行位于中心。行值可能沿途变化,但必须位于中心。 #define numRows 3 #define numCols 7 #define
我有2张 table : 第一个是“人”: person_id, 人名 第二个是“PersonsGraphs”: person_id1, person_id2, 关系类型 我正在寻找一种建立“家谱”的
是否可以在序列化 JSON 响应的同时根据 If 条件排除某些元素? if(a == 1) { //show element } else { //don't show element }
是否可以在序列化 JSON 响应的同时根据 If 条件排除某些元素? if(a == 1) { //show element } else { //don't show element }
尝试使用 jQuery 编写一个条件,该条件基本上说明,如果 div.gathering 不包含 a.cat-link,则执行以下操作。我已经尝试过以下方法,但似乎不起作用。有人能解释一下吗? if(
该练习要求插入值 x 的副本(这也是要在列表中搜索的值),但前提是该位置是另一个值 n 的倍数。未指定副本应插入到 x 值之前还是之后。 我的问题是并非在所有情况下都插入副本。我认为问题在于,当我插入
我遇到了这个[问题]:How can I store values into a multi-parameter struct and pass typedef struct to a functio
出于某种原因,当我编写 getWinner() 时,它仅适用于 2 种情况(最后一行)。就对角线和列而言,我拥有其他一切,但第 2 行(嗯,三,但数组,所以 2)基本上只适用于 o。只有当 o 位于
我有一个问题。 我想将“guid”列中的值复制到“帖子内容” 所有行都在一个表“wp-posts”中 “postparent”列中的一行有一个值,而“ID”列中的另一项也有相同的值 我必须做的事情是
我想将两个像这样的表合并到一个表中,并为重复的键行添加合并表中最旧的 DateAdded 值。 (Key1,Key2) 是主键。 +-----------+-----------+------+---
通过下面的表格和数据,我试图获得最高的 effective_from每个唯一 brand 小于当前时间戳的值/model组合 - 实际上是每件商品的当前价格。 CREATE TABLE things
您能告诉我如何删除未知号码的最后一条记录(有条件)吗? 例如,在这种情况下我想删除id为6到10的记录。 注意:该表和记录不是恒定的。 +----+-----+---------+ | id | ur
这个问题不太可能对任何 future 的访客有帮助;它只与一个较小的地理区域、一个特定的时间点或一个非常狭窄的情况相关,通常不适用于全世界的互联网受众。如需帮助使此问题更广泛适用,visit the
我有两个表, 标签 -> id,name,description,user,status 标签_连接。 -> id, Label_id, 类别 所以有多个类别,假设 1 => 新的,2 => 旧的。
好的,我会长话短说。 这是我的代码 String s = edittextkata.getText().toString(); String[] vowels = {"a","
我有一个非常具体的要求,我发现很难做到,我需要查找并替换文件中的某些行,但问题是文本不同,唯一的好处是它们都有一个 .[扩展名] 例如: 30/07/2012 14:46 17
我有一个大型数据库,其中存在各种不一致之处。我想澄清的项目之一是根据人口更改国家/地区状态。 数据样本是: { "_id" : "D", "name" : "Deutschland", "pop" :
我需要将范围(有条件)中的唯一值组合到同一行的另一个范围中。 其实我前两天发过类似的问题Link所提供的答案在我提出上述问题时有效。 但后来,我遇到了一个新问题,我宁愿问一个新的问题,让它更清楚: (
我刚开始使用 VBA,并且正在努力处理需要清理的工作表。 我有一列包含混合邮政编码和城市名称的字符串。我想从 A 列中提取邮政编码并放在 B 列中,并在 C 列中提取带有下划线的城市名称。 我的(示例
我是一名优秀的程序员,十分优秀!