如何将从Anorm中的executeInsert返回的Any转换为Long

jak*_*kob 2 scala anorm playframework-2.1

在我的Scala Playframework应用程序中,我正在尝试executeInsert创建一个sms_token(类).然后使用主键创建唯一令牌,将其添加到sms_token并保存executeUpdate.

case class SmsToken(id: Option[Long], token: String, phoneNumber: String, startDate: Option[Date], endDate: Option[Date], used: Boolean, tempReviewGrade: Option[Int], tempReviewText: Option[String])

object SmsToken {
  val simple = {
    get[Option[Long]]("id") ~
      get[String]("token") ~
      get[String]("phone_number") ~
      get[Option[Date]]("start_date") ~
      get[Option[Date]]("end_date") ~
      get[Boolean]("used") ~
      get[Option[Int]]("temp_review_grade") ~
      get[Option[String]]("temp_review_text") map {
      case id ~ token ~ phone_number ~ start_date ~ end_date ~ used ~ temp_review_grade ~ temp_review_text => SmsToken(id, token, phone_number, start_date, end_date, used, temp_review_grade, temp_review_text)
    }
  }
}
Run Code Online (Sandbox Code Playgroud)

方法:

 def createToken(n: String): Option[Long] = {

    var addedTokenPk = 0L

    val result = DB.withConnection {
      implicit connection =>
        SQL("insert into sms_token(token, phone_number, start_date, end_date, used, temp_review_grade, temp_review_text) values({token},{phone_number},{start_date},{end_date},{used}, {temp_review_grade}, {temp_review_text})").on(
          'token -> "",
          'phone_number -> n,
          'start_date -> new Date(),
          'end_date -> new Date(),
          'used -> 0,
          'temp_review_grade -> 0,
          'temp_review_text -> ""
        ).executeInsert()
    }
    result match {
      case Some(pk) => {
        addedTokenPk = pk.asInstanceOf[Long]
      }
      case None => println("YAAARRRRR")
    }

    if (addedTokenPk != 0L) {

      val token = Util.createUniqueToken(addedTokenPk)

      DB.withConnection {
        implicit connection =>
          SQL("update sms_token s set s.token={token} where s.id={id}").on(
            'id -> ("" + addedTokenPk).toLong,
            'token -> token
          ).executeUpdate()
      }
      return Some(addedTokenPk)
    }
    None
  }
Run Code Online (Sandbox Code Playgroud)

我的问题是关于这一部分:

result match {
    case Some(pk) => {
        addedTokenPk = pk.asInstanceOf[Long]
    }
    case None => println("YAAARRRRR")
}
Run Code Online (Sandbox Code Playgroud)

executeInsert返回一个Any对象,因为密钥是Long我正在做,asInstanceOf[Long] 因为我稍后在更新部分需要它.我是Scala noob所以我不确定这是否正确..也许有更好的Scala方式?

max*_*xmc 5

你得到的长ID,如果你调用mapexecuteInsert结果

DB.withConnection { implicit connection =>
   SQL("...").executeInsert().map(id => println(id))
}
Run Code Online (Sandbox Code Playgroud)

  • 必须是我的Intellij IDEA疯狂.​​.....它适用于你的例子......这很奇怪 (2认同)