Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/scala/18.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Postgresql Scala-找到意外的可空-左联接_Postgresql_Scala_Playframework_Left Join_Nullable - Fatal编程技术网

Postgresql Scala-找到意外的可空-左联接

Postgresql Scala-找到意外的可空-左联接,postgresql,scala,playframework,left-join,nullable,Postgresql,Scala,Playframework,Left Join,Nullable,我的Scala应用程序一直收到一个意外的NullableFound错误,我希望能得到一些帮助来纠正这个错误 错误:- [error] application - Unable to log user in. An exception was thrown java.lang.RuntimeException: Left(UnexpectedNullableFound(ColumnName(.language,Some(language))))

我的Scala应用程序一直收到一个意外的NullableFound错误,我希望能得到一些帮助来纠正这个错误

错误:-

[error] application - Unable to log user in. An exception was thrown
java.lang.RuntimeException: Left(UnexpectedNullableFound(ColumnName(.language,Some(language))))                                                                                             at anorm.MayErr$$anonfun$get$1.apply(MayErr.scala:35) ~[anorm_2.11-2.4.0.jar:2.4.0]                                                                                                 at anorm.MayErr$$anonfun$get$1.apply(MayErr.scala:34) ~[anorm_2.11-2.4.0.jar:2.4.0]                                                                                                 at scala.util.Either.fold(Either.scala:98) ~[scala-library-2.11.12.jar:na]                at anorm.MayErr.get(MayErr.scala:34) ~[anorm_2.11-2.4.0.jar:2.4.0]
        at anorm.Row$class.unsafeGet(Row.scala:103) ~[anorm_2.11-2.4.0.jar:2.4.0]
        at anorm.Cursor$ResultRow.unsafeGet(Cursor.scala:77) ~[anorm_2.11-2.4.0.jar:2.4.0]        at anorm.Row$class.apply(Row.scala:80) ~[anorm_2.11-2.4.0.jar:2.4.0]                      at anorm.Cursor$ResultRow.apply(Cursor.scala:77) ~[anorm_2.11-2.4.0.jar:2.4.0]
        at models.UserModel$$anonfun$findUserByEmailAndPassword$1$$anonfun$apply$9.apply(UserModel.scala:162) ~[classes/:na]
        at models.UserModel$$anonfun$findUserByEmailAndPassword$1$$anonfun$apply$9.apply(UserModel.scala:156) ~[classes/:na]
这是我认为可能导致此错误的代码:-

  def findUserByEmailAndPassword(email: String, password: String, browserHeaders: String, ip: String): Option[SocialUser] = DB.withConnection(db) { implicit c =>
    SQL"""
    select * from find_user_by_email_and_password($email, $password, $browserHeaders, inet($ip))
    """().map(row => (row[Option[Long]]("id"),
      row[Option[String]]("email"),
      row[Option[Int]]("verification"),
      row[Option[Boolean]]("on_mailing_list"),
      row[Option[Boolean]]("tfa_enabled"),
      row[Option[String]]("pgp"),
      row[String]("language")) match {
        case (Some(id: Long),
          Some(email: String),
          Some(verification: Int),
          Some(on_mailing_list: Boolean),
          Some(tfa_enabled: Boolean),
          pgp: Option[String],
          language: String) =>
          Some(SocialUser(id, email, verification, language, on_mailing_list, tfa_enabled, pgp))
        case _ =>
          None
      }
    ).head

任何帮助都将不胜感激。

您将从
language
列中获取
row[String](“语言”)
,但此列包含
NULL


您需要将其写为
行[Option[String]](“language”)
或使数据库方案中的language列
不为空

非常感谢你的帮助。您的建议还要求我在“language:String”行前面添加一些()。