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