2

当我使用ScalaQuery编程时,如何构建“从表中选择计数(*)”语句?

我用了一个

查询(TestTable.count)

但生成的选择语句是:

select count(*) from (select column1 from TestTable t2) t1

我想要:

从 TestTable 中选择 count(*)

对不起我糟糕的英语。


import org.scalaquery.ql.extended.MySQLDriver.Implicit._
import org.scalaquery.session._
import org.scalaquery.session.Database.threadLocalSession
import org.scalaquery.ql.Query
import org.scalaquery.ql.basic.{BasicTable => Table}

object Test {
  val db = Database.forURL(...)
  db withSession {
    val q = Query(TestTable.count)
    println(q.selectStatement)
  }
}
object TestTable extends Table[(Long, Int)]("test") {
  def id = column[Long]("id")
  def config = column[Int]("config")
  def * = id ~ config
}
4

1 回答 1

4

我不应该这么快就称它为错误。生成的代码是正确的,但显然并不理想。从 ScalaQuery 0.9.0 开始,您只能通过手动将 CountAll 运算符插入查询 AST 来获得所需的语句:

TestTable.map(t => ColumnOps.CountAll(t))

我刚刚提交了一项更改以改善这种情况,以便在许多情况下避免不必要的子查询。在 ScalaQuery 0.9.1 中,您最初的尝试“Query(TestTable.count)”应该按预期工作。

于 2010-09-26T13:01:55.463 回答