为什么 Anorm 在插入主键作为文本时抛出 TypeDoesNotMatch 异常?
Why does Anorm throw a TypeDoesNotMatch exception when inserting a Primary Key as Text?
我在 Postgres 9.4 中有一个 table,它以电子邮件地址作为主键。使用 Anorm,然后我执行以下操作
DB.withConnection { implicit connection =>
SQL"insert into member_login_email(email, password) values ($email, $password)".executeInsert()
}
执行此操作时,将正确的值输入 table,但抛出 TypeDoesNotMatch 运行时异常:
at play.api.Application$class.handleError(Application.scala:296) ~[play_2.11-2.3.7.jar:2.3.7]
at play.api.DefaultApplication.handleError(Application.scala:402) [play_2.11-2.3.7.jar:2.3.7]
at play.core.server.netty.PlayDefaultUpstreamHandler$$anonfun$$anonfun$applyOrElse.apply(PlayDefaultUpstreamHandler.scala:320) [play_2.11-2.3.7.jar:2.3.7]
at play.core.server.netty.PlayDefaultUpstreamHandler$$anonfun$$anonfun$applyOrElse.apply(PlayDefaultUpstreamHandler.scala:320) [play_2.11-2.3.7.jar:2.3.7]
at scala.Option.map(Option.scala:145) [scala-library-2.11.1.jar:na]
Caused by: java.lang.RuntimeException: TypeDoesNotMatch(Cannot convert dsfsfadsf@ddd.com: class java.lang.String to Long for column ColumnName(member_login_email.email,Some(email)))
at scala.sys.package$.error(package.scala:27) ~[scala-library-2.11.1.jar:na]
at anorm.Sql$.anorm$Sql$$as(Anorm.scala:472) ~[anorm_2.11-2.3.7.jar:2.3.7]
at anorm.Sql$class.executeInsert(Anorm.scala:350) ~[anorm_2.11-2.3.7.jar:2.3.7]
at anorm.SimpleSql.executeInsert(Anorm.scala:190) ~[anorm_2.11-2.3.7.jar:2.3.7]
at repository.MemberLoginEmailRepository$$anonfun$create.apply(MemberLoginEmailRepository.scala:17) ~[classes/:na]
似乎 Anorm 期望主键是 Long 类型。有没有办法让 Anorm 在不抛出异常的情况下接受文本类型的主键?
我查看了 source code for Anorm,但一直在努力寻找实际发生的位置。
默认情况下,executeInsert()
使用 ResultSetParser[Option[Long]]
从数据库中解析主键 return。从 scaladocs:
可以看出
def executeInsert[A](generatedKeysParser: ResultSetParser[A] = SqlParser.scalar[Long].singleOpt)
要使用 String
主键进行此操作,您可以改用:
executeInsert(SqlParser.scalar[String].singleOpt)
这将 return 一个 Option[String]
。
我在 Postgres 9.4 中有一个 table,它以电子邮件地址作为主键。使用 Anorm,然后我执行以下操作
DB.withConnection { implicit connection =>
SQL"insert into member_login_email(email, password) values ($email, $password)".executeInsert()
}
执行此操作时,将正确的值输入 table,但抛出 TypeDoesNotMatch 运行时异常:
at play.api.Application$class.handleError(Application.scala:296) ~[play_2.11-2.3.7.jar:2.3.7]
at play.api.DefaultApplication.handleError(Application.scala:402) [play_2.11-2.3.7.jar:2.3.7]
at play.core.server.netty.PlayDefaultUpstreamHandler$$anonfun$$anonfun$applyOrElse.apply(PlayDefaultUpstreamHandler.scala:320) [play_2.11-2.3.7.jar:2.3.7]
at play.core.server.netty.PlayDefaultUpstreamHandler$$anonfun$$anonfun$applyOrElse.apply(PlayDefaultUpstreamHandler.scala:320) [play_2.11-2.3.7.jar:2.3.7]
at scala.Option.map(Option.scala:145) [scala-library-2.11.1.jar:na]
Caused by: java.lang.RuntimeException: TypeDoesNotMatch(Cannot convert dsfsfadsf@ddd.com: class java.lang.String to Long for column ColumnName(member_login_email.email,Some(email)))
at scala.sys.package$.error(package.scala:27) ~[scala-library-2.11.1.jar:na]
at anorm.Sql$.anorm$Sql$$as(Anorm.scala:472) ~[anorm_2.11-2.3.7.jar:2.3.7]
at anorm.Sql$class.executeInsert(Anorm.scala:350) ~[anorm_2.11-2.3.7.jar:2.3.7]
at anorm.SimpleSql.executeInsert(Anorm.scala:190) ~[anorm_2.11-2.3.7.jar:2.3.7]
at repository.MemberLoginEmailRepository$$anonfun$create.apply(MemberLoginEmailRepository.scala:17) ~[classes/:na]
似乎 Anorm 期望主键是 Long 类型。有没有办法让 Anorm 在不抛出异常的情况下接受文本类型的主键?
我查看了 source code for Anorm,但一直在努力寻找实际发生的位置。
默认情况下,executeInsert()
使用 ResultSetParser[Option[Long]]
从数据库中解析主键 return。从 scaladocs:
def executeInsert[A](generatedKeysParser: ResultSetParser[A] = SqlParser.scalar[Long].singleOpt)
要使用 String
主键进行此操作,您可以改用:
executeInsert(SqlParser.scalar[String].singleOpt)
这将 return 一个 Option[String]
。