メインコンテンツまでスキップ
バージョン: 2.5

array_contains

説明

配列が特定の要素を含んでいるかどうかを確認します。含んでいる場合は1を返し、そうでない場合は0を返します。

構文

array_contains(any_array, any_element)

mysql> select array_contains(["apple","orange","pear"], "orange");
+-----------------------------------------------------+
| array_contains(['apple','orange','pear'], 'orange') |
+-----------------------------------------------------+
| 1 |
+-----------------------------------------------------+
1 row in set (0.01 sec)

配列がNULLを含んでいるかどうかも確認できます。

mysql> select array_contains([1, NULL], NULL);
+--------------------------------+
| array_contains([1,NULL], NULL) |
+--------------------------------+
| 1 |
+--------------------------------+
1 row in set (0.00 sec)

多次元配列が特定のサブ配列を含んでいるかどうかを確認できます。このとき、サブ配列の要素が正確に一致していること、要素の並び順も含めて確認する必要があります。

mysql> select array_contains([[1,2,3], [4,5,6]], [4,5,6]);
+--------------------------------------------+
| array_contains([[1,2,3],[4,5,6]], [4,5,6]) |
+--------------------------------------------+
| 1 |
+--------------------------------------------+
1 row in set (0.00 sec)

mysql> select array_contains([[1,2,3], [4,5,6]], [4,6,5]);
+--------------------------------------------+
| array_contains([[1,2,3],[4,5,6]], [4,6,5]) |
+--------------------------------------------+
| 0 |
+--------------------------------------------+
1 row in set (0.00 sec)

キーワード

ARRAY_CONTAINS, ARRAY