2016-03-23 7 views
0

私は滑らかな問題があります。それはそれを使用した後のように見えるスカラーは静的型言語ではありません:) ^^;残念ながら、結果がのタイプの[ProcessUserRoleDto]のProcessUserRoleDtoを持つ通常のケースクラスであり、実際にはの値を保持しています。一部は(1)であり、 '1'はタイプのjava.lang.Integerです。これはどのように可能ですか?この問題を解決する方法はありますか?SlickとSql Serverのストアドプロシージャを使用している場合のClassCastException

case class ProcessUserRoleDto(
    processUserRoleId: Int, 
    processUserId: Int, 
    processRoleId: Int, 
    dataCollectionId: Int, 
    recognizingInstanceId: Int, 
    processRoleName: String, 
    dataCollectionName: String, 
    recognizingInstanceName: String, 
    isActive: Boolean) 

def assign(dto: ProcessUserRoleAssignDto): Future[Option[ProcessUserRoleDto]] = { 
    val db = implicitly[SQLServerDriver.backend.DatabaseDef] 
    val sql = sql"exec EVO.spProcessUserRoleAssignToRecognizingInstance ${dto.ProcessUser_ID}, ${dto.ProcessRole_ID}, ${dto.RecognizingInstance_ID}" 

    implicit val registerProcessUserResult = GetResult { r => 
     ProcessUserRoleDto(r.<<, r.<<, r.<<, r.<<, r.<<, r.<<, r.<<, r.<<, r.<<) 
    } 
    val resultFut: Future[Option[ProcessUserRoleDto]] = db 
           .run(sql.as[ProcessUserRoleDto]) 
           .map(_.headOption) 

    val singleResult: Option[ProcessUserRoleDto] = Await.result(resultFut, 10 seconds) 

    println(s"singleResult = $singleResult") 
    // in runtime result was: Some(1) 
    // WTF ?!? 

    println(s"class inside Some() = ${singleResult.get.getClass.getCanonicalName}") 
    // in runtime result is: java.lang.Integer 

    println(s"Option[Class] = ${singleResult.map(_.getClass.getCanonicalName)}") 
    // here exception is thrown: java.lang.ClassCastException: java.lang.Integer cannot be cast to ProcessUserRoleDto 
} 

答えて

0

ストアドプロシージャは、insertステートメントを実行してからselectステートメントを実行していました。挿入が変更されたレコードの数を返すため、ストアドプロシージャに "SET NOCOUNT ON"を追加するとその(https://stackoverflow.com/a/4809815/1185138)が停止したため、JDBCドライバが混乱していました。

まだ滑らかで、それについての素晴らしいエラーメッセージを再送するのではなく、うんざりしてしまいます。

関連する問題