对于scalikejdbc,如何使用外键约束编写QueryDSL

时间:2014-06-12 09:06:18

标签: scala types scalikejdbc

我使用scalikejdbc 2.0.1和playframework 2.3。我按照一对多http://scalikejdbc.org/documentation/one-to-x.html的指示,但仍然有错误:

我的数据模型是一个拥有许多Todo的帐户:

Todo模特:

case class Todo (id: Long, value: String, userId:Option[Long] = None, users: Option[Account] = None){}
object Todo extends SQLSyntaxSupport[Todo]{
    val todo = syntax("todo")
    override val tableName = "todo"
    private val auto = AutoSession
    def opt(m: ResultName[Todo])(rs: WrappedResultSet) = rs.longOpt(m.id).map(_ => Todo(m)(rs))
    apply(todo.resultName)(rs)
    def apply(a: ResultName[Todo])(rs: WrappedResultSet): Todo = new Todo(
        id         = rs.long(todo.id),
        userId     =rs.longOpt(todo.userId),
        value      = rs.string(todo.value)
        )

    def apply(m: ResultName[Todo], a: ResultName[Account])(rs: WrappedResultSet) =  {
        apply(m)(rs).copy(users = rs.longOpt(a.id).map(_ => Account(a)(rs)))
    }


}

模型账户是:

case class Account(id: Int, email: String, password: String, name: String, permission: Role,todos:Seq[Todo]=Nil)

object Account extends SQLSyntaxSupport[Account] {
...
    val (a, t) = (Account.syntax, Todo.syntax)
    val accounts: List[Account] = withSQL {
    select.from(Account as a).leftJoin(Todo as t).on(a.id,t.userId)
    }.one(Account(a))
    .toMany(Todo.opt(t))
    .map { (account, todos) => account.copy( todos = todos) }
    .list.apply()
    }
}

我得到的错误是:

[error] G:\testprojects\mifun\app\models\Todo.scala:23: overloaded method apply
needs result type
[error]     apply(m)(rs).copy(users = rs.longOpt(a.id).map(_ => Account(a)(rs)))
[error]          ^
[error] G:\testprojects\mifun\app\models\Account.scala:53: type mismatch;
[error]  found   : scalikejdbc.QuerySQLSyntaxProvider[scalikejdbc.SQLSyntaxSuppo
rt[models.Todo],models.Todo]
[error]  required: scalikejdbc.ResultName[models.Todo]
[error]     (which expands to)  scalikejdbc.ResultNameSQLSyntaxProvider[scalikej
dbc.SQLSyntaxSupport[models.Todo],models.Todo]
[error]     .toMany(Todo.opt(t))
[error]                      ^
[error] two errors found
[error] (compile:compile) Compilation failed

我有两个问题:

1,为什么我不能用到很多?我想使用ResultNameSQLSyntaxProvider,如何更改我写的opt函数?

2,什么rs类型应该给Todo.scala:23?

1 个答案:

答案 0 :(得分:2)

  1,为什么我不能用到很多?我想使用ResultNameSQLSyntaxProvider,如何更改我写的opt函数?

抱歉,这是由于文档错误造成的。更新opt方法,如下所示:

def opt(m: SyntaxProvider[Todo])(rs: WrappedResultSet) 
  = rs.longOpt(m.resultName.id).map(_ => Todo(m.resultName)(rs))

或者像这样添加重载方法:

def opt(m: SyntaxProvider[Todo])(rs: WrappedResultSet): Option[Todo] = opt(m.resultName)(rs)
  

2,什么rs类型应该给Todo.scala:23?

正如错误消息所示,应在Scala中使用显式返回类型定义重载方法。

def apply(m: ResultName[Todo], a: ResultName[Account])(rs: WrappedResultSet) =  {
  apply(m)(rs).copy(users = rs.longOpt(a.id).map(_ => Account(a)(rs)))
}

上述方法应该是这样的:

def apply(m: ResultName[Todo], a: ResultName[Account])(rs: WrappedResultSet): Todo =  {
  apply(m)(rs).copy(users = rs.longOpt(a.id).map(_ => Account(a)(rs)))
}