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)
    }
  }
}
方法:
 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
  }
我的问题是关于这一部分:
result match {
    case Some(pk) => {
        addedTokenPk = pk.asInstanceOf[Long]
    }
    case None => println("YAAARRRRR")
}
executeInsert返回一个Any对象,因为密钥是Long我正在做,asInstanceOf[Long] 
因为我稍后在更新部分需要它.我是Scala noob所以我不确定这是否正确..也许有更好的Scala方式?
你得到的长ID,如果你调用map的executeInsert结果
DB.withConnection { implicit connection =>
   SQL("...").executeInsert().map(id => println(id))
}
| 归档时间: | 
 | 
| 查看次数: | 1888 次 | 
| 最近记录: |