表 9.53 显示了可用于数组类型的专用运算符。除了这些运算符之外,表 9.1 中显示的常用比较运算符也可用于数组。比较运算符使用元素数据类型的默认 B 树比较函数逐个元素比较数组内容,并根据第一个差异进行排序。在多维数组中,元素按行优先顺序访问(最后一个下标变化最快)。如果两个数组的内容相等,但维数不同,则维数信息中的第一个差异将决定排序顺序。
表 9.53 数组运算符
运算符 说明 示例 |
---|
第一个数组是否包含第二个数组,即第二个数组中出现的每个元素是否等于第一个数组的某个元素?(重复项没有特殊处理,因此
|
第一个数组是否包含在第二个数组中?
|
数组是否有重叠,即是否有任何元素相同?
|
连接两个数组。连接空数组或 null 数组不会执行任何操作;否则,数组必须具有相同数量的维数(如第一个示例所示)或维数相差一(如第二个示例所示)。如果数组的元素类型不相同,则会将它们强制转换为公共类型(请参阅第 10.5 节)。
|
将一个元素连接到数组(该数组必须为空或一维)的前面。
|
将一个元素连接到数组(该数组必须为空或一维)的末尾。
|
有关数组运算符行为的更多详细信息,请参阅 第 8.15 节。有关哪些运算符支持索引操作的更多详细信息,请参阅 第 11.2 节。
表 9.54 显示了可用于数组类型的函数。有关这些函数的使用情况的更多信息和示例,请参阅 第 8.15 节。
表 9.54. 数组函数
函数 说明 示例 |
---|
将一个元素追加到数组的末尾(与
|
连接两个数组(与
|
返回数组维度文本表示形式。
|
返回一个数组,其中填充给定值的副本,其维度由第二个参数指定的长度决定。可选的第三个参数为每个维度提供下限值(默认为全部
|
返回请求的数组维度的长度。(对于空或缺失的数组维度,生成 NULL 而不是 0。)
|
返回请求的数组维度的下限。
|
返回数组的维度数。
|
返回数组中第二个参数的第一个出现位置的下标,如果不存在,则返回
|
返回一个数组,其中包含作为第一个参数提供的数组中所有第二个参数出现位置的脚标。数组必须是一维的。比较使用
|
将一个元素添加到数组的开头(与
|
从数组中删除所有等于给定值的所有元素。数组必须是一维的。比较使用
|
将等于第二个参数的每个数组元素替换为第三个参数。
|
从
|
随机打乱数组的第一个维度。
|
将每个数组元素转换为其文本表示形式,并用
|
返回请求的数组维度的上限。
|
返回数组中元素的总数,如果数组为空,则返回 0。
|
通过移除最后
|
将数组展开成一组行。数组的元素按存储顺序读出。
1 2
foo bar baz quux |
将多个数组(可能具有不同的数据类型)展开成一组行。如果数组长度不一致,则使用
a | b ---+----- 1 | foo 2 | bar | baz |
另请参见 第 9.21 节,了解用于数组的聚合函数 array_agg
。