mirror of
https://github.com/postgres/postgres.git
synced 2025-10-24 01:29:19 +03:00
Doc: clarify handling of duplicate elements in array containment tests.
The array <@ and @> operators do not worry about duplicates: if every member of array X matches some element of array Y, then X is contained in Y, even if several members of X get matched to the same Y member. This was not explicitly stated in the docs though, so improve matters. Discussion: https://postgr.es/m/156614120484.1310.310161642239149585@wrigleys.postgresql.org
This commit is contained in:
@@ -11671,14 +11671,14 @@ SELECT NULLIF(value, '(none)') ...
|
|||||||
<row>
|
<row>
|
||||||
<entry> <literal>@></literal> </entry>
|
<entry> <literal>@></literal> </entry>
|
||||||
<entry>contains</entry>
|
<entry>contains</entry>
|
||||||
<entry><literal>ARRAY[1,4,3] @> ARRAY[3,1]</literal></entry>
|
<entry><literal>ARRAY[1,4,3] @> ARRAY[3,1,3]</literal></entry>
|
||||||
<entry><literal>t</literal></entry>
|
<entry><literal>t</literal></entry>
|
||||||
</row>
|
</row>
|
||||||
|
|
||||||
<row>
|
<row>
|
||||||
<entry> <literal><@</literal> </entry>
|
<entry> <literal><@</literal> </entry>
|
||||||
<entry>is contained by</entry>
|
<entry>is contained by</entry>
|
||||||
<entry><literal>ARRAY[2,7] <@ ARRAY[1,7,4,2,6]</literal></entry>
|
<entry><literal>ARRAY[2,2,7] <@ ARRAY[1,7,4,2,6]</literal></entry>
|
||||||
<entry><literal>t</literal></entry>
|
<entry><literal>t</literal></entry>
|
||||||
</row>
|
</row>
|
||||||
|
|
||||||
@@ -11721,8 +11721,10 @@ SELECT NULLIF(value, '(none)') ...
|
|||||||
</table>
|
</table>
|
||||||
|
|
||||||
<para>
|
<para>
|
||||||
Array comparisons compare the array contents element-by-element,
|
The array ordering operators (<literal><</literal>,
|
||||||
using the default B-tree comparison function for the element data type.
|
<literal>>=</literal>, etc) compare the array contents
|
||||||
|
element-by-element, using the default B-tree comparison function for
|
||||||
|
the element data type, and sort based on the first difference.
|
||||||
In multidimensional arrays the elements are visited in row-major order
|
In multidimensional arrays the elements are visited in row-major order
|
||||||
(last subscript varies most rapidly).
|
(last subscript varies most rapidly).
|
||||||
If the contents of two arrays are equal but the dimensionality is
|
If the contents of two arrays are equal but the dimensionality is
|
||||||
@@ -11733,6 +11735,15 @@ SELECT NULLIF(value, '(none)') ...
|
|||||||
number of dimensions or subscript ranges were different.)
|
number of dimensions or subscript ranges were different.)
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
|
<para>
|
||||||
|
The array containment operators (<literal><@</literal>
|
||||||
|
and <literal>@></literal>) consider one array to be contained in
|
||||||
|
another one if each of its elements appears in the other one.
|
||||||
|
Duplicates are not treated specially, thus <literal>ARRAY[1]</literal>
|
||||||
|
and <literal>ARRAY[1,1]</literal> are each considered to contain the
|
||||||
|
other.
|
||||||
|
</para>
|
||||||
|
|
||||||
<para>
|
<para>
|
||||||
See <xref linkend="arrays"> for more details about array operator
|
See <xref linkend="arrays"> for more details about array operator
|
||||||
behavior. See <xref linkend="indexes-types"> for more details about
|
behavior. See <xref linkend="indexes-types"> for more details about
|
||||||
|
Reference in New Issue
Block a user