slickに次のようなクエリを作成させたい
select max(price) from coffees where ...
しかし、slickのドキュメントは役に立ちません
val q = Coffees.map(_.price) //this is query Query[Coffees.type, ...]
val q1 = q.min // this is Column[Option[Double]]
val q2 = q.max
val q3 = q.sum
val q4 = q.avg
これらのq1-q4はクエリではないため、結果を取得することはできませんが、他のクエリ内で使用することはできます。
この文
for {
coffee <- Coffees
} yield coffee.price.max
正しいクエリを生成しますが、非推奨になります(警告を生成します:「クラスColumnExtensionMethodsのメソッドmaxは非推奨になりました:代わりにQuery.maxを使用してください」)。 警告なしにそのようなクエリを生成する方法は?
もう1つの問題は、groupbyで集計することです。
"select name, max(price) from coffees group by name"
でそれを解決しようとしました
for {
coffee <- Coffees
} yield (coffee.name, coffee.price.max)).groupBy(x => x._1)
を生成します
select x2.x3, x2.x3, x2.x4 from (select x5."COF_NAME" as x3, max(x5."PRICE") as x4 from "coffees" x5) x2 group by x2.x3
これは明らかなdbエラーを引き起こします
column "x5.COF_NAME" must appear in the GROUP BY clause or be used in an aggregate function
そのようなクエリを生成する方法は?