gpt4 book ai didi

arrays - 为什么 `array_ndims(array[])` 会产生 NULL?

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

我正在尝试测试一个空数组。我理解 array_length 返回 NULL 背后的原因,因为它是一个 0 维数组,但为什么 array_ndims(array[]::int array)不是 0,而是 NULL

最佳答案

看起来它永远不会返回 0:

/* Sanity check: does it look like an array at all? */
if (AARR_NDIM(v) <= 0 || AARR_NDIM(v) > MAXDIM)
PG_RETURN_NULL();

您可以为此编写自己的 C 函数,只需更改 <= 0进入< 0 .至于这背后的原因,我找不到任何东西。

来源位于:https://www.postgresql.org/ftp/source/v10.1/ (对于 9.6.2 也是一样,with 是我最初检查的)

文件:./src/backend/utils/adt/arrayfuncs.c

寻找简单的 10 行函数:array_ndims

关于arrays - 为什么 `array_ndims(array[])` 会产生 NULL?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48022753/

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