0

我在使用字符串插值执行普通 SQL 查询时遇到了一些麻烦。我正在尝试使用 Microsoft 的 sqljdbc4.jar 查询 MS-SQL 2008 数据库。

表很简单:

[serv_num]
number (nvarchar(15))  |  name (nvarchar(50))
=============================================
    1234               |     AA
    +345               |     BB

我正在使用的代码如下:

import java.sql.{Connection, DriverManager}
import org.slf4j.LoggerFactory
import scala.collection.JavaConversions._
import scala.slick.session.Database
import Database.threadLocalSession
import scala.slick.jdbc.{GetResult, StaticQuery => Q}
import Q.interpolation

object NumImport extends App {
    def logger = LoggerFactory.getLogger("NumImport")
    implicit val getServNumResult = GetResult(r => ServNum(r.<<, r.<<))

    override def main(args: Array[String]) {
        val uri = "jdbc:sqlserver://192.168.1.2;databaseName=slicktestdb;user=yyyy;password=xxxxxx"
        val drv = "com.microsoft.sqlserver.jdbc.SQLServerDriver"

        Database.forURL(uri, driver = drv) withSession {
           def getServNum(n: String) = sql"select number, name from serv_num where number = $n".as[ServNum]
           val result = getServNum("1234")
           println(result.firstOption)
        }
    }

    case class ServNum(num: String, name: String)
}

我的问题是我正在接受java.lang.NullPointerExceptionresult.firstOption我认为!)。当找到一行时会发生这种情况。如果尝试选择一个不存在的数字,比如getServNum("34"),那么正如预期的那样result.firstOption是 a 。None

堆栈跟踪:

08:54:47.932 TKD [run-main] DEBUG scala.slick.session.BaseSession - Preparing statement: select number, name from serv_num where number = ?
[error] (run-main) java.lang.NullPointerException
java.lang.NullPointerException
at scala.slick.jdbc.StaticQuery.extractValue(StaticQuery.scala:16)
at scala.slick.jdbc.StatementInvoker$$anon$1.extractValue(StatementInvoker.scala:37)
at scala.slick.session.PositionedResultIterator.foreach(PositionedResult.scala:212)
at scala.slick.jdbc.Invoker$class.foreach(Invoker.scala:91)
at scala.slick.jdbc.StatementInvoker.foreach(StatementInvoker.scala:10)
at scala.slick.jdbc.Invoker$class.firstOption(Invoker.scala:41)
at scala.slick.jdbc.StatementInvoker.firstOption(StatementInvoker.scala:10)
at scala.slick.jdbc.UnitInvoker$class.firstOption(Invoker.scala:148)
at scala.slick.jdbc.StaticQuery0.firstOption(StaticQuery.scala:95)

我尝试调试并跟踪堆栈跟踪,但我对 Scala 和 Slick 都很陌生,所以我迷路了。如果有人可以帮助我或指出我正确的方向,我将不胜感激。

谢谢。

4

1 回答 1

1

在查看异常发生的光滑源代码时,我可以看到它试图在对象上调用applyGetResult但该对象似乎为空。在考虑可能导致它的原因时,我建议您移动 main 方法的隐式内部。似乎事物的结构方式,光滑正在失去对隐式ResultSet到案例类转换器(的GetResult)的跟踪

于 2013-05-24T10:11:09.200 回答