Я пытаюсь перейти на 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]
Я использую slick.driver.MySQLDriver $ / com.mysql.jdbc.Driver в application.conf, а файл models.Tables.scala автоматически создается slick-codegen lib.
Может ли кто-нибудь помочь мне это исправить? Спасибо!