4

ScalikeJDBC の SQL 補間で in-clauses を使用できますか? 例えば

val ids = Set(1,2,3,5)
sql"""update foo set bar=${bar} where id in ${ids}""".update().apply()

idsは補間されていないため、これは失敗します。

sql"""update foo set bar=${bar} where id in (${ids.mkString(",")})""".update().apply()

式が数値のリストではなく文字列として解釈されるため、これも失敗します。例えば... where id in ('1,2,3,5')

4

1 に答える 1

6

私はあなたの問題を理解していませんが、 Set 値の補間はうまくいくはずです。

libraryDependencies ++= Seq(
  "org.scalikejdbc" %% "scalikejdbc"       % "2.2.6",
  "com.h2database"  %  "h2"                % "1.4.187",
  "ch.qos.logback"  %  "logback-classic"   % "1.1.3"
)

このような:

scala> import scalikejdbc._
import scalikejdbc._

scala> val ids = Set(1,2,3,5)
ids: scala.collection.immutable.Set[Int] = Set(1, 2, 3, 5)

scala> val s = sql"""update foo set bar=1 where id in (${ids})"""
s: scalikejdbc.SQL[Nothing,scalikejdbc.NoExtractor] = scalikejdbc.SQLToTraversableImpl@633229c7

scala> s.statement
res1: String = update foo set bar=1 where id in (?, ?, ?, ?)

scala> s.parameters
res2: Seq[Any] = List(1, 2, 3, 5)
于 2015-05-04T11:37:43.630 に答える