Nano Hash - криптовалюты, майнинг, программирование

Как выполнить условие JOIN в Pig?

У меня есть два отношения A, B

DESCIBE A
A:{ip_num:long,data:int}

DESCIBE B
B:{ip_start_num:long,ip_end_num:long}

Я хочу получить продукт:

C:{group:(ip_start_num:long, ip_end_num:long), B:{(ip_num:long, data:int)}}

where ip_num >ip_start_num && ip_num < ip_end_num

есть ли возможность сделать с PigLatin?


Ответы:


1

Однако вам нужно будет выполнить операцию FILTER внутри вложенного FOREACH; похоже там баг, так что такое предложение даже не разобрать. https://issues.apache.org/jira/browse/PIG-1798. Этот пост также относится к той же проблеме. ИСПОЛЬЗОВАНИЕ фильтра во вложенном FOREACH в PIG

Вчера я столкнулся с той же проблемой, и было два доступных решения: первое — написать UDF для фильтрации по диапазону IP-адресов. Во-вторых, найти способ сделать простое соединение между двумя отношениями, чтобы у вас могло быть это другое отношение:

D:{ip_num:long,data:int,ip_start_num:long,ip_end_num:long}.

Там вы можете фильтровать без вложенного foreach. Я выбрал второй вариант, однако это не всегда способ выполнить соединение.

28.06.2012

2

Боюсь, в Свинье нет тета-соединений. Вы можете выполнить перекрестное соединение с последующим фильтром. Будьте осторожны с результирующим взрывом данных.

15.04.2015
Новые материалы

Кластеризация: более глубокий взгляд
Кластеризация — это метод обучения без учителя, в котором мы пытаемся найти группы в наборе данных на основе некоторых известных или неизвестных свойств, которые могут существовать. Независимо от..

Как написать эффективное резюме
Предложения по дизайну и макету, чтобы представить себя профессионально Вам не позвонили на собеседование после того, как вы несколько раз подали заявку на работу своей мечты? У вас может..

Частный метод Python: улучшение инкапсуляции и безопасности
Введение Python — универсальный и мощный язык программирования, известный своей простотой и удобством использования. Одной из ключевых особенностей, отличающих Python от других языков, является..

Как я автоматизирую тестирование с помощью Jest
Шутка для победы, когда дело касается автоматизации тестирования Одной очень важной частью разработки программного обеспечения является автоматизация тестирования, поскольку она создает..

Работа с векторными символическими архитектурами, часть 4 (искусственный интеллект)
Hyperseed: неконтролируемое обучение с векторными символическими архитектурами (arXiv) Автор: Евгений Осипов , Сачин Кахавала , Диланта Хапутантри , Тимал Кемпития , Дасвин Де Сильва ,..

Понимание расстояния Вассерштейна: мощная метрика в машинном обучении
В обширной области машинного обучения часто возникает необходимость сравнивать и измерять различия между распределениями вероятностей. Традиционные метрики расстояния, такие как евклидово..

Обеспечение масштабируемости LLM: облачный анализ с помощью AWS Fargate и Copilot
В динамичной области искусственного интеллекта все большее распространение получают модели больших языков (LLM). Они жизненно важны для различных приложений, таких как интеллектуальные..