gpt4 book ai didi

java - 使用NamedParameterJdbcTemplate更新数组字段

转载 作者:行者123 更新时间:2023-11-29 14:12:58 26 4
gpt4 key购买 nike

我在表myTable中有一个 double 组字段dblArrayFld,我想使用Spring的NamedParameterJdbcTemplate更新它(我'我使用 Postgres)。

我正在运行这样的代码:

SqlParameterSource params = (new MapSqlParameterSource())
.addValue("myarray", myDblArrayListVar)
.addValue("myid", 123);

namedJdbcTemplate.update("UPDATE myTable SET dblArrayFld = :myarray WHERE idFld = :myid", params);

这会返回一个错误,读取“$2”处或附近的语法错误

我假设我的 :myarray 语法在这里有问题。我还尝试通过以下方式封装 :myarray:

  • dblArrayFld={:myarray}
  • dblArrayFld={ :myarray }
  • dblArrayFld=[:myarray]
  • dblArrayFld=ARRAY[:myarray]
  • dblArrayFld=(:myarray)

这里正确的语法是什么?

最佳答案

当您尝试将 Collection 或数组绑定(bind)为命名参数时,NamedParameterJdbcTemplate 会将语句中相应的命名参数分解为多个与数组/集合长度匹配的位置参数。这对于 WHERE column IN (:param) 语句很有用,但在这种情况下不起作用。

为了设置实际的 Postgres 数组,您必须提供参数 java.sql.Array 。您可以使用 Connection#createArrayOf() 创建其实例方法。

关于java - 使用NamedParameterJdbcTemplate更新数组字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1658102/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com