数据库
首页 > 数据库> > mysql-播放2.4-Slick 3.0.0-删除不起作用

mysql-播放2.4-Slick 3.0.0-删除不起作用

作者:互联网

我正在尝试升级到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,并且models.Tables.scala文件由slick-codegen lib自动生成.

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

解决方法:

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

我只是遇到了同样的问题,发现此错误报告很光滑:https://github.com/playframework/play-slick/issues/249

标签:scala,mysql,playframework,slick,play-slick
来源: https://codeday.me/bug/20191010/1887614.html