Play 2.4 - Slick 3.0.0 - DELETE не работает

Я пытаюсь перейти на 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.

Может ли кто-нибудь помочь мне это исправить? Спасибо!


person Carlos Souza    schedule 29.05.2015    source источник
comment
возможный дубликат Scala Slick delete не работает   -  person Peanut    schedule 29.05.2015
comment
Я видел этот ответ и не мог связать его со своей проблемой, поскольку Slick 3.0 сильно отличается от Slick 2.1.   -  person Carlos Souza    schedule 29.05.2015


Ответы (2)


Попробуйте импортировать более конкретный API, поэтому вместо import driver.api._ используйте import slick.driver.MySQLDriver.api._.

У меня была такая же проблема, и я нашел этот отчет об ошибке для ловкости: https://github.com/playframework/play-slick/issues/249

person Mirko Stocker    schedule 29.05.2015

H2 базы данных

Если вы используете H2, а не MySQL, нижеприведенное исправление для меня с благодарностью Карлос и Мирко здесь:

import slick.driver.H2Driver.api._ 

замена старого:

import driver.api._

Надеюсь, delete поддержка скоро появится в общем API!

person bjfletcher    schedule 10.06.2015