postgresql - 在 PostgresSQL 中计算阶乘函数时出现“bigint out of range”
问题描述
作为数据库类介绍的一部分,我们被告知使用 PL/pgSQL 创建一个函数,该函数给出一个数字的阶乘。现在因为 x! 作为一个函数迅速增加,我们决定返回一个,bigint
因为它是一个大范围的整数。
CREATE OR REPLACE FUNCTION getBigFactorial(fn bigint) RETURNS bigint as $$
DECLARE
product bigint;
minus1 int;
BEGIN
if (fn > 21) then
RAISE EXCEPTION 'Error: computing factorial; numeric value out of range';
return NULL;
elsif (fn < 1) then
RAISE EXCEPTION 'Error: Argument less than 1!';
return NULL;
end if;
minus1 := fn - 1;
if (minus1 > 0) then
product := fn * getBigFactorial(minus1);
return product;
end if;
return fn;
END;
$$ language plpgsql;
对于这个函数,我们被告知要为输入的数字创建某种验证。一个(fn < 1)
完美地工作,然而,一个(fn > 21)
是给一些问题。
输入以下内容时:
SELECT getBigFactorial(21);
我们得到:
ERROR: bigint out of range
CONTEXT: PL/pgSQL function getbigfactorial(integer) line 17 at assignment
SQL state: 22003
而不是得到想要的输出。第 17 行对应于这一行:
if (minus1 > 0) then
当我们输入 22 而不是 21 时,我们得到了所需的错误输出。
有什么帮助找出导致这种情况的原因吗?TIA
解决方案
您的条件检查应包括21
:
if (fn >= 21) then
-- ...
因为对于 的输入21
,21 的阶乘(fn * getBigFactorial(minus1)
,其中fn
= 21 和minus1
= fn
- 1),它是一个超出 a 范围的整数bigint
,被分配给product
, a bigint
。
推荐阅读
- tensorflow - AI Platform 作业以非零状态 1 退出。终止原因:错误
- amazon-web-services - Athena 将特殊字符显示为?
- sql - 匹配 SQL 上月底的值
- odoo - 单击信用票据发票odoo中的添加按钮时如何编辑操作
- mysql - 没有使用visual basic在mysql中获取插入数据
- python - 如何将列表的每个项目转换为字典?
- php - 使用 PHP 使用 Powershell 脚本登录 Azure
- javascript - 为什么 request.user 的值看起来不一致?
- excel - 如何对包含具有一般格式的日期的列进行查找和替换?
- javascript - 将对象推入对象数组会复制该数组中已经存在的对象