我正在尝试使用scalikejdbc来访问包含数组字段的模式,即
CREATE TABLE foo (
id INTEGER PRIMARY KEY,
events TEXT[] NOT NULL
);我在文档或示例中找不到任何关于数组的东西,我只能通过查看scalikejdbc源代码来猜测。
我的模型看起来像
case class Foo(id: Long, events: Array[String])
object Foo extends SQLSyntaxSupport[Foo] with ShortenedNames {
override val columnNames = Seq("id", "events")
private val s = syntax("s")
private def apply(sp: SyntaxProvider[Foo])(rs: WrappedResultSet): Foo = apply(sp.resultName)(rs)
private def apply(rn: ResultName[Foo])(rs: WrappedResultSet): Foo = Foo(
id = rs.get(rn.id),
events = rs.get(rn.events)
)
// ...
}和编译器的抱怨
erroneous or inaccessible type events = rs.get(rn.events)
^如果我将提取器代码更改为
events = rs.array(rn.events).getArray.asInstanceOf[Array[String]]它编译得很好,但我得到了运行时异常
Execution exception[[UnsupportedOperationException: null]]那么如何使用scalikejdbc访问数组字段呢?
发布于 2014-08-26 15:59:53
我发现结果应该转换为Buffer
events = rs.any(rn.events).asInstanceOf[Buffer[String]]发布于 2014-08-27 16:22:44
您使用的是哪种RDBMS?我猜UnsupportedOperationException是由您的JDBC驱动程序实现抛出的。我刚刚尝试了一个简单的例子,通过简单地在H2数据库中使用java.sql.Array#getArray()来从java.sql.Array值中提取数组值,它工作得很好。
https://stackoverflow.com/questions/25481363
复制相似问题