如何使用play2.6 slick3更新sql server的标识列?

时间:2018-03-22 09:29:41

标签: sql-server scala playframework slick slick-3.0

当我尝试使用sql server运行sbt scala项目时出现以下错误

[SQLServerException:无法更新标识列' ID'。]

我正在使用Play 2.6,Scala 2.12,Slick 3

我的更新功能是,

def update(id: Long): Action[AnyContent] = Action.async { implicit request =>
    topicForm.bindFromRequest.fold(
      formWithErrors => Future.successful(BadRequest(html.editForm(id, formWithErrors))),
      topic => {
        val futureTopUpdate = dao.update(id, topic.copy(id = Some(id)))
        futureTopUpdate.map { result =>
          Home.flashing("success" -> "Topic %s has been updated".format(topic.code))
        }.recover {
          case ex: TimeoutException =>
            Logger.error("Problem found in topic update process")
            InternalServerError(ex.getMessage)
        }
      })
  }

和DAO:

override def update(id: Long, topic: Topic): Future[Int] =
try db.run(filterQuery(id).update(topic))
finally db.close

任何想法?

1 个答案:

答案 0 :(得分:0)

你可以展示 filterQuery(id)实现,类似的东西在我们这个方面很有效:

  override def update(id: Long, topic: Topic): Future[Int] = {
          db.run(filterQuery(id).update(topic.copy(id))
  }

注意:主题。复制(id)

filterQuery是:

def filterQuery(id: Int) = themes.filter(_.id === id)

我们使用Play 2.6,Scala 2.12,Slick 3和MYSQL。

更新#1:

- >实体:

case class CategoryRow(id: Int, name: String, description: String)

- >映射:

trait CategoryMapping {
  self: HasDatabaseConfigProvider[JdbcProfile] =>
  import dbConfig.profile.api._

  private[models] class CategoryTable(tag: Tag)
    extends Table[CategoryRow](tag, "category") {

    def id = column[Int]("id", O.AutoInc, O.PrimaryKey)

    def name = column[String]("name", O.Length(TextMaxLength_250))

    def description = column[String]("description", Nullable)

    def categoryNameAgencyIndex = index("categoryName_agency_idx", (name, agencyId), unique = true)

    override def * = (
      id,
      name,
      description
    ) <> (CategoryRow.tupled, CategoryRow.unapply)
  }

  private[models] val Categories = TableQuery[CategoryTable]
  private[models] val CategoriesInsertQuery = Categories returning Categories.map(_.id)
}

- &GT; REPO

 trait CategoryRepository {
    //...    
      def update(id: Int, category: Category)(implicit agencyId: Int): Future[Int]    
    //...

    }

- &GT; REPOImpl:

@Singleton
class CategoryRepositoryImpl @Inject()(protected val dbConfigProvider: DatabaseConfigProvider)(implicit ec: RepositoryExecutionContext)
  extends CategoryRepository with HasDatabaseConfigProvider[JdbcProfile] with CategoryMapping {

  import dbConfig.profile.api._
//....
     def update(id: Int, category: CategoryRow)(implicit agencyId: Int): Future[Int] =
       db.run(filter(id).update(category.copy(id)))

     private def filter(id: Int) = Categories.filter(_.id === id)
//....
}

- &GT; RepositoryExecutionContex

class RepositoryExecutionContext @Inject()(actorSystem: ActorSystem) extends CustomExecutionContext(actorSystem, "repository.dispatcher")

和aplication.conf:

# db connections = ((physical_core_count * 2) + effective_spindle_count)
fixedConnectionPool = 5

repository.dispatcher {
  executor = "thread-pool-executor"
  throughput = 1
  thread-pool-executor {
    fixed-pool-size = ${fixedConnectionPool}
  }
}

Chapter 3.3 Essential Slick中有关于折叠的更多信息。