gpt4 book ai didi

hibernate - 如何在 PostgreSQL 的文字字符串中使用 '

转载 作者:行者123 更新时间:2023-11-29 14:22:03 32 4
gpt4 key购买 nike

我了解到 JPA- Hibernate 不支持 INTERVAL 关键字。为了解决这个问题,我尝试编写一个函数,该函数又使用 INTERVAL 关键字。我需要做的就是从 Hibernate 调用这个函数。

下面是我要写的函数。它抛出语法错误。

CREATE OR REPLACE FUNCTION getTimeStampAfterDeductingHours(abc varchar) returns TIMESTAMPTZ  as
$$
select CURRENT_TIMESTAMP - INTERVAL ''' ' || abc || 'hour ';
$$ language 'sql';

错误:类型间隔的输入语法无效:“'”

基本上我想在SQL语句中使用输入参数。我尝试了很多方法来包含它。但是做不到。

最佳答案

错误是:

ERROR:  invalid input syntax for type interval: "' "
LINE 3: select CURRENT_TIMESTAMP - INTERVAL ''' ' || abc || 'hour ...
^

那是因为您只能对区间文字使用 INTERVAL 'some-interval-here' 模式。 PostgreSQL 将 INTERVAL 绑定(bind)得比 || 运算符更紧密,因此您正在做:

(INTERVAL ''' ') || ...

这没有意义。

在这种情况下,您必须构造一个字符串,然后将其转换INTERVAL

select CURRENT_TIMESTAMP - CAST(''' ' || abc || 'hour ' AS interval);

我不知道你想用前导 ' 实现什么,而且在没有看到你发送到函数的输入的情况下我真的猜不到。

根据函数名称猜测,您实际上想从当前时间戳中减去作为参数传递的小时数。如果是这样,你应该传递一个整数,而不是一个字符串,并乘以间隔:

CREATE OR REPLACE FUNCTION getTimeStampAfterDeductingHours(hours integer) returns TIMESTAMPTZ  as
$$
SELECT current_timestamp - (hours * INTERVAL '1' HOUR);
$$ language 'sql';

关于hibernate - 如何在 PostgreSQL 的文字字符串中使用 ',我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21473259/

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