Советы по анализу
Функции MEDIAN() и PERCENTILE()
- В режиме Live функции MEDIAN() и PERCENTILE() (начиная с версии коннектора v0.1.3) используют функцию ClickHouse quantile()(), что существенно ускоряет вычисления, но основано на выборочном методе. Если вам нужны точные результаты вычислений, используйте функции
MEDIAN_EXACT()иPERCENTILE_EXACT()(на основе quantileExact()()). - В режиме Extract нельзя использовать функции MEDIAN_EXACT() и PERCENTILE_EXACT(), потому что MEDIAN() и PERCENTILE() всегда дают точный (и медленный) результат.
Дополнительные функции для вычисляемых полей в режиме Live
ClickHouse предоставляет обширный набор функций для анализа данных — значительно больше, чем поддерживает Tableau. Для удобства пользователей мы добавили новые функции, доступные в режиме Live при создании вычисляемых полей (Calculated Fields). К сожалению, в интерфейсе Tableau невозможно добавить описания этих функций, поэтому мы приводим их описание непосредственно здесь.
-IfAggregation Combinator (добавлено в v0.2.3) — позволяет использовать фильтры на уровне строк непосредственно в агрегатных вычислениях. Добавлены функцииSUM_IF(), AVG_IF(), COUNT_IF(), MIN_IF() & MAX_IF().BAR([my_int], [min_val_int], [max_val_int], [bar_string_length_int])(добавлено в v0.2.1) — Забудьте о скучных столбчатых диаграммах! Вместо этого используйте функциюBAR()(эквивалентbar()в ClickHouse). Например, это вычисляемое поле возвращает наглядные столбики в виде строки (String):COUNTD_UNIQ([my_field])(добавлена в v0.2.0) — Вычисляет приблизительное число различных значений аргумента. Эквивалент функции uniq(). Гораздо быстрее, чемCOUNTD().DATE_BIN('day', 10, [my_datetime_or_date])(добавлена в v0.2.1) — эквивалент функцииtoStartOfInterval()в ClickHouse. Округляет дату или дату и время в меньшую сторону до указанного интервала, например:FORMAT_READABLE_QUANTITY([my_integer])(добавлена в v0.2.1) — Возвращает округлённое число с суффиксом (тысяча, миллион, миллиард и т. д.) в виде строки. Полезна для удобства чтения больших чисел. ЭквивалентformatReadableQuantity().FORMAT_READABLE_TIMEDELTA([my_integer_timedelta_sec], [optional_max_unit])(добавлено в v0.2.1) — Принимает временной интервал в секундах. Возвращает интервал в виде строки с единицами (год, месяц, день, час, минута, секунда).optional_max_unit— максимальная единица, которую нужно отобразить. Допустимые значения:seconds,minutes,hours,days,months,years. ЭквивалентformatReadableTimeDelta().GET_SETTING([my_setting_name])(добавлено в v0.2.1) — Возвращает текущее значение пользовательской настройки. Эквивалент функцииgetSetting().HEX([my_string])(добавлено в v0.2.1) — Возвращает строку, содержащую шестнадцатеричное представление аргумента. Аналог функцииhex().KURTOSIS([my_number])— вычисляет выборочный эксцесс (куртозис) для последовательности. ЭквивалентнаkurtSamp().KURTOSISP([my_number])— Вычисляет эксцесс распределения для последовательности значений. Эквивалент функцииkurtPop().MEDIAN_EXACT([my_number])(добавлено в v0.1.3) — Точно вычисляет медиану последовательности числовых данных. ЭквивалентноquantileExact(0.5)(...).MOD([my_number_1], [my_number_2])— вычисляет остаток от деления. Если аргументы являются числами с плавающей точкой, они предварительно преобразуются в целые числа с отбрасыванием дробной части. Эквивалент функцииmodulo().PERCENTILE_EXACT([my_number], [level_float])(добавлено в v0.1.3) — Точно вычисляет значение процентиля для числовой последовательности данных. Рекомендуемый диапазон параметра уровня — [0.01, 0.99]. Эквивалент функцииquantileExact()().PROPER([my_string])(добавлено в v0.2.5) — Преобразует текстовую строку таким образом, что первая буква каждого слова становится заглавной, а остальные буквы — строчными. Пробелы и небуквенно-цифровые символы, например знаки препинания, также считаются разделителями. Например:RAND()(добавлено в v0.2.1) — возвращает целое число (UInt32), например3446222955. Эквивалент функцииrand().RANDOM()(добавлена в v0.2.1) — неофициальная функция TableauRANDOM(), которая возвращает вещественное число от 0 до 1.RAND_CONSTANT([optional_field])(добавлено в v0.2.1) — создает константный столбец со случайным значением. Что-то вроде{RAND()}Fixed LOD, но быстрее. Эквивалент функцииrandConstant().REAL([my_number])— Приводит поле к числу с плавающей точкой (Float64). Подробностиздесь.SHA256([my_string])(добавлено в v0.2.1) — вычисляет хэш SHA-256 от строки и возвращает результирующий набор байтов в виде строки (FixedString). Удобно использовать вместе с функциейHEX(), например,HEX(SHA256([my_string])). АналогSHA256().SKEWNESS([my_number])— Вычисляет выборочную асимметрию последовательности значений. Эквивалент функцииskewSamp().SKEWNESSP([my_number])— Вычисляет коэффициент асимметрии числовой последовательности. Эквивалент функцииskewPop().TO_TYPE_NAME([field])(добавлено в v0.2.1) — Возвращает строку, содержащую имя типа ClickHouse для переданного аргумента. Эквивалент функцииtoTypeName().TRUNC([my_float])— То же самое, что функцияFLOOR([my_float]). Эквивалент функцииtrunc().UNHEX([my_string])(добавлено в v0.2.1) — Выполняет операцию, обратнуюHEX(). Эквивалент функцииunhex().