Перейти к основному содержимому

percentile_approx_raw

Описание

Возвращает значение, соответствующее указанному процентилю из x.

Если x является столбцом, эта функция сначала сортирует значения в x в порядке возрастания и возвращает значение, соответствующее процентилю y.

Синтаксис

PERCENTILE_APPROX_RAW(x, y);

Параметры

  • x: Может быть столбцом или набором значений. Должен иметь тип PERCENTILE.

  • y: процентиль. Поддерживаемый тип данных — DOUBLE. Диапазон значений: [0.0,1.0].

Возвращаемое значение

Возвращает значение типа PERCENTILE.

Примеры

Создайте таблицу aggregate_tbl, где столбец percent является входным параметром для percentile_approx_raw().

CREATE TABLE `aggregate_tbl` (
`site_id` largeint(40) NOT NULL COMMENT "id of site",
`date` date NOT NULL COMMENT "time of event",
`city_code` varchar(20) NULL COMMENT "city_code of user",
`pv` bigint(20) SUM NULL DEFAULT "0" COMMENT "total page views",
`percent` PERCENTILE PERCENTILE_UNION COMMENT "others"
) ENGINE=OLAP
AGGREGATE KEY(`site_id`, `date`, `city_code`)
COMMENT "OLAP"
DISTRIBUTED BY HASH(`site_id`)
PROPERTIES ("replication_num" = "1");

Вставьте данные в таблицу.

insert into aggregate_tbl values (5, '2020-02-23', 'city_code', 555, percentile_hash(1));
insert into aggregate_tbl values (5, '2020-02-23', 'city_code', 555, percentile_hash(2));
insert into aggregate_tbl values (5, '2020-02-23', 'city_code', 555, percentile_hash(3));
insert into aggregate_tbl values (5, '2020-02-23', 'city_code', 555, percentile_hash(4));

Вычислите значение, соответствующее процентилю 0.5.

mysql> select percentile_approx_raw(percent, 0.5) from aggregate_tbl;
+-------------------------------------+
| percentile_approx_raw(percent, 0.5) |
+-------------------------------------+
| 2.5 |
+-------------------------------------+
1 row in set (0.03 sec)