gpt4 book ai didi

java - 使用 Spring 的 NamedParamterJdbcTemplate 和命名参数进行分组

转载 作者:行者123 更新时间:2023-12-02 07:03:55 32 4
gpt4 key购买 nike

我正在使用 PostgreSQL 和 Spring 3.1 NamedParameterJdbcTemplate。

如果我有一些 SQL 在 Select & Group By 子句中使用命名参数,Postgres 会将其作为错误语法返回。使用手动替换的参数运行查询将正常工作。

假设有一个名为“table”的表,其中包含“id”和“number”两列

此 SQL:

从表 GROUP BY some_function(id, :param) 中选择 some_function(id, :param), avg(number)

变成(由数据库记录):

从表 GROUP BY some_function(id, $2) 中选择 some_function(id, $1), avg(number)

我怀疑查询计划程序查看此查询,但它不知道 $1==$2,因此它给出错误“列 'id' 必须出现在 GROUP BY 子句中或在聚合函数中使用。 ”

有没有办法使用 Spring 来解决这个问题?有什么方法可以获取它,以便查询变为:

SELECT some_function(id, $1), avg(number) FROM table GROUP BY some_function(id, $1)?我怀疑查询规划器对此不会有意见。

最佳答案

你可以写:

SELECT some_function(id, $1), avg(number) FROM table GROUP BY 1;

它将按 SELECT 结果的第一列 (some_function(id, $1)) 进行分组。

另一种方法是这样写:

SELECT grp, avg(number)
FROM (SELECT some_function(id, $1) as grp, number FROM table)
GROUP BY grp;

关于java - 使用 Spring 的 NamedParamterJdbcTemplate 和命名参数进行分组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16323638/

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