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

ARRAY_MAX

array_max

説明

配列内の最大値を計算します。この関数は配列内のすべての要素を反復処理し、最大値を見つけてそれを返します。

構文

array_max(ARRAY<T> arr)

パラメータ

  • arr:ARRAY 型、最大値を計算する配列。

T でサポートされる型:

  • 数値型: TINYINT, SMALLINT, INT, BIGINT, LARGEINT, FLOAT, DOUBLE, DECIMAL
  • 文字列型: CHAR, VARCHAR, STRING
  • 日付と時刻型: DATE, DATETIME, DATEV2, DATETIMEV2
  • Boolean型: BOOLEAN
  • IP型: IPV4, IPV6

戻り値

戻り値の型: T

戻り値の意味:

  • 配列内の最大値を返す
  • NULL: 配列が空の場合、またはすべての要素がnullの場合

使用上の注意:

  • 配列内の要素を比較することで返す要素を決定し、同一データ型の要素の比較をサポート
  • 配列がNULLの場合、型変換エラーを返す
  • 配列要素のnull値について: null要素は比較に含まれない

クエリ例:

浮動小数点配列の最大値を計算:

SELECT array_max([5.5, 2.2, 8.8, 1.1, 9.9, 3.3]);
+-------------------------------------------+
| array_max([5.5, 2.2, 8.8, 1.1, 9.9, 3.3]) |
+-------------------------------------------+
| 9.9 |
+-------------------------------------------+

文字列配列の最大値を(辞書順で)計算する:

SELECT array_max(['zebra', 'appleeee', 'banana', 'cherry']);
+------------------------------------------------------+
| array_max(['zebra', 'appleeee', 'banana', 'cherry']) |
+------------------------------------------------------+
| zebra |
+------------------------------------------------------+

null値を含む配列の最大値を計算する:

SELECT array_max([5, null, 2, null, 8, 1]);
+-------------------------------------+
| array_max([5, null, 2, null, 8, 1]) |
+-------------------------------------+
| 8 |
+-------------------------------------+

空の配列はNULLを返します:

SELECT array_max([]);
+------------------+
| array_max([]) |
+------------------+
| NULL |
+------------------+

すべての要素がnullの配列はNULLを返します:

SELECT array_max([null, null, null]);
+----------------------------------+
| array_max([null, null, null]) |
+----------------------------------+
| NULL |
+----------------------------------+

日付配列の最大値:

SELECT array_max(cast(['2023-01-01', '2022-12-31', '2023-06-15'] as array<datetime>));
+--------------------------------------------------------------------------------+
| array_max(cast(['2023-01-01', '2022-12-31', '2023-06-15'] as array<datetime>)) |
+--------------------------------------------------------------------------------+
| 2023-06-15 00:00:00 |
+--------------------------------------------------------------------------------+

IP アドレス配列の最大値:

SELECT array_max(CAST(['192.168.1.100', '192.168.1.1', '192.168.1.50'] AS ARRAY<IPV4>));
+----------------------------------------------------------------------------------+
| array_max(CAST(['192.168.1.100', '192.168.1.1', '192.168.1.50'] AS ARRAY<IPV4>)) |
+----------------------------------------------------------------------------------+
| 192.168.1.100 |
+----------------------------------------------------------------------------------+

SELECT array_max(CAST(['2001:db8::1', '2001:db8::2', '2001:db8::0'] AS ARRAY<IPV6>));
+-------------------------------------------------------------------------------+
| array_max(CAST(['2001:db8::1', '2001:db8::2', '2001:db8::0'] AS ARRAY<IPV6>)) |
+-------------------------------------------------------------------------------+
| 2001:db8::2 |
+-------------------------------------------------------------------------------+

複雑な型の例:

ネストした配列型はサポートされておらず、エラーになります:

SELECT array_max([[1,2],[3,4],[5,6]]);
ERROR 1105 (HY000): errCode = 2, detailMessage = array_max does not support complex types: array_max([[1, 2], [3, 4], [5, 6]])

Map型はサポートされていません。エラーになります:

SELECT array_max([{'k':1},{'k':2},{'k':3}]);
ERROR 1105 (HY000): errCode = 2, detailMessage = array_max does not support complex types: array_max([map('k', 1), map('k', 2), map('k', 3)])

パラメータ数が間違っている場合のエラー:

SELECT array_max([1,2,3], [4,5,6]);
ERROR 1105 (HY000): errCode = 2, detailMessage = Can not found function 'array_max' which has 2 arity. Candidate functions are: [array_max(Expression)]

非配列型を渡した際のエラー:

SELECT array_max('not_an_array');
ERROR 1105 (HY000): errCode = 2, detailMessage = class org.apache.doris.nereids.types.VarcharType cannot be cast to class org.apache.doris.nereids.types.ArrayType (org.apache.doris.nereids.types.VarcharType and org.apache.doris.nereids.types.ArrayType are in unnamed module of loader 'app')

配列がNULLの場合、型変換エラーを返します:

mysql> SELECT array_max(NULL);
ERROR 1105 (HY000): errCode = 2, detailMessage = class org.apache.doris.nereids.types.NullType cannot be cast to class org.apache.doris.nereids.types.ArrayType (org.apache.doris.nereids.types.NullType and org.apache.doris.nereids.types.ArrayType are in unnamed module of loader 'app')

Keywords

ARRAY、MAX、ARRAY_MAX