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

INTERVAL

説明

INTERVAL関数は、バイナリサーチを使用してNより厳密に大きい最初の閾値のインデックスを返します。この関数は、バイナリサーチアルゴリズムを正しく使用し、最適なパフォーマンスを実現するために、閾値パラメータが昇順でソートされている必要があります(N1 ≤ N2 ≤ N3 ≤ ... ≤ Nn)。

  • すべてのパラメータは整数として扱われます。
  • 時間計算量O(log n)のバイナリサーチアルゴリズムを使用し、優れたパフォーマンスを提供します。

この関数は、MySQLのinterval functionと一貫した動作をします。

構文

INTERVAL(N, N1, N2, N3, ...)

パラメータ

Parameterデスクリプション
N検索する値、integer型。
N1, N2, N3, ...閾値のリスト、integer型、昇順でソートされている必要があります(N1 ≤ N2 ≤ N3 ≤ ... ≤ Nn)。少なくとも1つの閾値パラメータが必要です。

戻り値

Nより厳密に大きい最初の閾値のインデックス(0ベース)を返します。戻り値の型はintegerです。

NがNULLの場合、-1を返します。

閾値パラメータ(N1, N2, ...)がNULLの場合、0として扱われます。

-- Basic usage
SELECT INTERVAL(23, 1, 15, 17, 30, 44, 200);
+-----------------------------------------+
| INTERVAL(23, 1, 15, 17, 30, 44, 200) |
+-----------------------------------------+
| 3 |
+-----------------------------------------+

SELECT INTERVAL(10, 1, 10, 100, 1000);
+-----------------------------------+
| INTERVAL(10, 1, 10, 100, 1000) |
+-----------------------------------+
| 2 |
+-----------------------------------+

-- Boundary case: less than the first threshold
SELECT INTERVAL(0, 1, 10, 100);
+--------------------------+
| INTERVAL(0, 1, 10, 100) |
+--------------------------+
| 0 |
+--------------------------+

-- Boundary case: greater than all thresholds
SELECT INTERVAL(200, 1, 10, 100);
+----------------------------+
| INTERVAL(200, 1, 10, 100) |
+----------------------------+
| 3 |
+----------------------------+

-- Boundary case: equal to a threshold
SELECT INTERVAL(33, 1, 10, 32, 33, 102, 200);
+-------------------------------------------+
| INTERVAL(33, 1, 10, 32, 33, 102, 200) |
+-------------------------------------------+
| 4 |
+-------------------------------------------+

-- First parameter is NULL
SELECT INTERVAL(NULL, 1, 10, 100);
+----------------------------+
| INTERVAL(NULL, 1, 10, 100) |
+----------------------------+
| -1 |
+----------------------------+

-- Subsequent parameters are NULL, treated as 0
SELECT INTERVAL(3, -1, NULL, 2, 3, 4);
+--------------------------------+
| INTERVAL(3, -1, NULL, 2, 3, 4) |
+--------------------------------+
| 4 |
+--------------------------------+

-- NULL values causing unsorted sequence, resulting in incorrect binary search result
SELECT INTERVAL(20, 7, NULL, 14, NULL, 25, NULL, 50);
+-----------------------------------------------+
| INTERVAL(20, 7, NULL, 14, NULL, 25, NULL, 50) |
+-----------------------------------------------+
| 6 |
+-----------------------------------------------+

-- Input single parameter, error
SELECT INTERVAL(33);
ERROR 1105 (HY000): errCode = 2, detailMessage = Can not find the compatibility function signature: interval(TINYINT)