【问题标题】:Play 2.4 - Slick 3.0.0 - DELETE not working播放 2.4 - Slick 3.0.0 - 删除不起作用
【发布时间】:2015-08-12 05:13:58
【问题描述】:

我正在尝试升级到 Slick 3.0.0 和 Play 2.4 (Scala),但 删除 行不起作用。在下面的代码中,一切正常:查询所有行、插入和更新 - 除了删除。

package dao

import scala.concurrent.Future
import models._
import models.Tables._
import play.api.Play
import play.api.db.slick.DatabaseConfigProvider
import play.api.db.slick.HasDatabaseConfig
import play.api.libs.concurrent.Execution.Implicits.defaultContext
import slick.driver.JdbcProfile

class UserDAO extends HasDatabaseConfig[JdbcProfile] {
  protected val dbConfig =  DatabaseConfigProvider.get[JdbcProfile](Play.current)

  import driver.api._

  def all(): Future[List[UserRow]] = db.run(Tables.User.result).map(_.toList)

  def findByEmail(email: String): Future[Option[UserRow]] = {
    db.run(Tables.User.filter(_.email === email).result.headOption)
  }

  def update(id: Int, newData: UserRow): Future[Int] = {
    db.run(Tables.User.filter(_.id === id).update(newData))
  }

  def delete(id: Int): Future[Int] = {
    db.run(Tables.User.filter(_.id === id).delete)
  }

}

代码产生如下编译错误:

value delete is not a member of slick.lifted.Query[models.Tables.User,models.Tables.User#TableElementType,Seq]

我在application.conf中使用slick.driver.MySQLDriver$/com.mysql.jdbc.Driver,slick-codegen lib自动生成models.Tables.scala文件。

谁能帮我解决这个问题? 谢谢!

【问题讨论】:

  • Scala Slick delete not working 的可能重复项
  • 我看到了这个答案,但无法将其与我的问题联系起来,因为 Slick 3.0 与 Slick 2.1 非常不同

标签: mysql scala playframework slick play-slick


【解决方案1】:

尝试导入更具体的 API,因此不要使用 import driver.api._,而是使用 import slick.driver.MySQLDriver.api._

我刚刚遇到了同样的问题,发现了这个关于 slick 的错误报告:https://github.com/playframework/play-slick/issues/249

【讨论】:

    【解决方案2】:

    H2 数据库

    如果您使用的是 H2 而不是 MySQL,以下感谢 CarlosMirko 为我修复了它:

    import slick.driver.H2Driver.api._ 
    

    替换旧的:

    import driver.api._
    

    我希望delete 支持很快就会进入通用 API!

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2023-03-26
      • 1970-01-01
      • 1970-01-01
      • 2018-11-01
      • 2017-10-10
      相关资源
      最近更新 更多