gpt4 book ai didi

hibernate - Postgres - 如何将 sum(bigint) 类型转换为 bigint?

转载 作者:行者123 更新时间:2023-11-29 13:35:28 28 4
gpt4 key购买 nike

我有一个 Postgres 8.2 表,其中列定义为 bigint 数据类型。

当我执行 sum(column) 时,返回类型是 numeric。我想强制将总和类型转换为 bigint,因为我确信结果不会超过 bigint 的最大值。我能够使用这样的子查询实现这一点:

select T.big_col_total::bigint from (select sum(big_col) as big_col_total from big_table) T;

有没有一种方法可以不使用子查询来做到这一点,也就是说,我可以以某种方式直接对 sum 进行类型转换吗?我尝试了几种方法,但都导致了语法错误。

(背景:我正在从 Hibernate 运行此查询,因此将查询的返回数据类型限制为 BigInteger 对我来说很重要。bigint + bigint = numeric(Java 端的 BigDecimal)

最佳答案

只需使用:

select sum(big_col)::bigint as total 
from big_table

并且您应该尽快升级到受支持的版本(例如 9.x)。

关于hibernate - Postgres - 如何将 sum(bigint) 类型转换为 bigint?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13730571/

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