我正在尝试将java中的一个函数转换为pl/pgsql,我发现的一个问题是,当我试图对2个负数求和,而a得到一个正数时,更具体地说:
public void sum(){
int n1 = -1808642602;
int n2 = -904321301;
System.out.println(n1 + n2);// result is 1582003393
}在pl/pgsql中,我得到一个整数超出范围的错误,如果我将变量类型更改为bigint,我会得到2个负数的正常和,即-2712963903,而不是1582003393
怎样才能让pl/pgsql得到相同的结果,而不打印一个整数超出范围的错误?
发布于 2011-02-26 03:46:16
发生这种情况是因为Java int溢出,并且没有告诉您。
为了得到你在pl中寻找的答案,你需要使用bigint。然后检测结果小于Java Integer.MIN_INT (-2^31)的情况,这就是Java将给出肯定结果的情况。要获得Java所能提供的功能,请添加2^32。
发布于 2011-02-26 03:28:05
你正在使int溢出,用long尝试同样的事情,它应该可以工作。
发布于 2011-02-26 03:28:14
它是溢出的,因为结果对于int来说太大了。请改用long。
https://stackoverflow.com/questions/5121698
复制相似问题