Play 2.4 - Slick 3.0.0 - DELETE 不起作用
Play 2.4 - Slick 3.0.0 - DELETE not working
我正在尝试升级到 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._
。
我刚刚遇到了同样的问题,发现了这个 slick 的错误报告:https://github.com/playframework/play-slick/issues/249
H2 数据库
如果你使用的是 H2 而不是 MySQL,下面已经为我修复了它,感谢 Carlos 和 Mirko 这里:
import slick.driver.H2Driver.api._
替换旧的:
import driver.api._
我希望 delete
支持很快进入 API!
我正在尝试升级到 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._
。
我刚刚遇到了同样的问题,发现了这个 slick 的错误报告:https://github.com/playframework/play-slick/issues/249
H2 数据库
如果你使用的是 H2 而不是 MySQL,下面已经为我修复了它,感谢 Carlos 和 Mirko 这里:
import slick.driver.H2Driver.api._
替换旧的:
import driver.api._
我希望 delete
支持很快进入 API!