首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用scalikejdbc访问数组?

使用scalikejdbc访问数组?
EN

Stack Overflow用户
提问于 2014-08-25 15:52:23
回答 2查看 834关注 0票数 0

我正在尝试使用scalikejdbc来访问包含数组字段的模式,即

代码语言:javascript
复制
CREATE TABLE foo (
  id         INTEGER      PRIMARY KEY,
  events     TEXT[]       NOT NULL
);

我在文档或示例中找不到任何关于数组的东西,我只能通过查看scalikejdbc源代码来猜测。

我的模型看起来像

代码语言:javascript
复制
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)
  )

  // ...
}

和编译器的抱怨

代码语言:javascript
复制
erroneous or inaccessible type events      = rs.get(rn.events)
                                                   ^

如果我将提取器代码更改为

代码语言:javascript
复制
events      = rs.array(rn.events).getArray.asInstanceOf[Array[String]]

它编译得很好,但我得到了运行时异常

代码语言:javascript
复制
Execution exception[[UnsupportedOperationException: null]]

那么如何使用scalikejdbc访问数组字段呢?

EN

回答 2

Stack Overflow用户

发布于 2014-08-26 15:59:53

我发现结果应该转换为Buffer

代码语言:javascript
复制
events      = rs.any(rn.events).asInstanceOf[Buffer[String]]
票数 1
EN

Stack Overflow用户

发布于 2014-08-27 16:22:44

您使用的是哪种RDBMS?我猜UnsupportedOperationException是由您的JDBC驱动程序实现抛出的。我刚刚尝试了一个简单的例子,通过简单地在H2数据库中使用java.sql.Array#getArray()来从java.sql.Array值中提取数组值,它工作得很好。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/25481363

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档