【问题标题】:implicit value for slick.jdbc.SetParameter[List[Int]]slick.jdbc.SetParameter[List[Int]] 的隐含值
【发布时间】:2019-10-09 23:59:03
【问题描述】:

我有一个由 PostgreSQL 支持的原始光滑查询。我想运行这样的查询:select something from my_table where action in (1,2,3)。请注意,action 是my_table 中的integer 字段

我在下面的方法中遇到编译错误:

找不到参数 e 的隐含值: slick.jdbc.SetParameter[List[Int]]

def myMethod(actions: List[Int]]) {
 sql"""select something from my_table 
        where action in (${actions})""".as[MyType]
}

问题

如何显式设置List[Int] 参数,以便成功运行in 查询?

【问题讨论】:

    标签: scala slick


    【解决方案1】:

    试试

    def myMethod(actions: List[Int]) =
      sql"""select something from my_table
            where action in #${actions.mkString("(", ",", ")")}""".as[MyType]
    

    http://slick.lightbend.com/doc/3.3.0/sql.html#splicing-literal-values

    https://www.w3schools.com/sql/sql_in.asp

    【讨论】:

    【解决方案2】:

    使用他的 slick-postgreSQL 扩展: https://github.com/tminglei/slick-pg

    更多信息: How to pass an array to a slick SQL plain query?

    implicit val setIntArray: SetParameter[Array[Int]] = mkArraySetParameter[Int](...)
    

    【讨论】:

      猜你喜欢
      • 2013-01-01
      • 1970-01-01
      • 1970-01-01
      • 2020-03-05
      • 1970-01-01
      • 2022-01-17
      • 1970-01-01
      • 1970-01-01
      • 2017-06-17
      相关资源
      最近更新 更多