ユニフォーム
説明
与えられたランダムシードを使用して、特定の範囲内で一様にサンプリングし、乱数を生成します。
構文
UNIFORM( <min> , <max> , <gen> )
パラメータ
| パラメータ | 説明 |
|---|---|
<min> | 乱数の下限、数値型を受け入れ、リテラルである必要がある |
<max> | 乱数の上限、数値型を受け入れ、リテラルである必要がある |
<gen> | 整数、乱数シード、通常は RANDOM 関数によってランダムに生成される |
戻り値
[<min>, <max>] 範囲内の乱数を返す。<min> と <max> の両方が整数の場合、戻り値の型は BIGINT となり、そうでなければ DOUBLE となる。
Snowflake の 一般的な使用法 とは異なり、Doris の RANDOM 関数はデフォルトで 0 と 1 の間の浮動小数点数を返すため、RANDOM() を乱数シードとして使用する場合は、結果が整数範囲内に分布するように乗数を付ける必要があることに注意してください。詳細は例を参照してください。
例
すべての入力パラメータが整数の場合、整数を返す:
select uniform(-100, 100, random() * 10000) as result from numbers("number" = "10");
+--------+
| result |
+--------+
| -82 |
| -79 |
| 21 |
| 19 |
| 50 |
| 53 |
| -100 |
| -67 |
| 46 |
| 40 |
+--------+
入力パラメータがすべて整数でない場合、double型を返します:
select uniform(1, 100., random() * 10000) as result from numbers("number" = "10");
+-------------------+
| result |
+-------------------+
| 84.25057360297031 |
| 63.34296160793329 |
| 81.8770598286311 |
| 26.53334147605743 |
| 17.42787914185705 |
| 2.532901549399078 |
| 63.72223367924216 |
| 78.42165786093118 |
| 18.913688179943 |
| 41.73057334477316 |
+-------------------+
リテラルパラメータである必要があります:
select uniform(1, unix_timestamp(), random() * 10000) as result from numbers("number" = "10");
ERROR 1105 (HY000): errCode = 2, detailMessage = The second parameter (max) of uniform function must be literal
リテラルパラメータである必要があります:
select uniform(1, ksint, random()) from fn_test;
ERROR 1105 (HY000): errCode = 2, detailMessage = The second parameter (max) of uniform function must be literal
固定されたシードは固定された結果を生成します(random()の結果は0と1の間に分布し、直接使用される場合、uniformのseedパラメータは常に0です):
select uniform(-100, 100, random()) as result from numbers("number" = "10");
+--------+
| result |
+--------+
| -68 |
| -68 |
| -68 |
| -68 |
| -68 |
| -68 |
| -68 |
| -68 |
| -68 |
| -68 |
+--------+
いずれかの入力がNULLの場合、出力もNULLになります:
select uniform(-100, NULL, random() * 10000) as result from numbers("number" = "10");
+--------+
| result |
+--------+
| NULL |
| NULL |
| NULL |
| NULL |
| NULL |
| NULL |
| NULL |
| NULL |
| NULL |
| NULL |
+--------+
select k0, uniform(0, 1000, k0) from it order by k0;
+------+----------------------+
| k0 | uniform(0, 1000, k0) |
+------+----------------------+
| NULL | NULL |
| 1 | 134 |
| 2 | 904 |
| 3 | 559 |
| 4 | 786 |
| 5 | 673 |
+------+----------------------+