Пример 1.
Exists
(Employee)
Возвращает -1 (True), если значение поля Employee в текущей записи уже существует в любой ранее прочитанной записи, содержащей это поле.
Операторы Exists (Employee, Employee) и Exists (Employee) эквивалентны.
Пример 2.
Exists(Employee,
'Bill')
Возвращает -1 (True), если значение поля 'Bill' найдено в текущем содержимом поля Employee.
Пример 3
Employees:
LOAD * inline [
Employee|ID|Salary
Bill|001|20000
John|002|30000
Steve|003|35000
] (delimiter is '|');
Citizens:
Load * inline [
Employee|Address
Bill|New York
Mary|London
Steve|Chicago
Lucy|Madrid
Lucy|Paris
John|Miami
] (delimiter is '|') where Exists (Employee);
Drop Tables Employees;
В результате будет получена таблица, которую можно использовать в визуализации таблицы с помощью измерений Employee и Address.
Предложение where, where Exists (Employee), означает только имена из таблицы Citizens, загруженные в новую таблицу, которые также находятся в таблице Employees. Оператор Drop удаляет таблицу Employees во избежание неопределенности.
Результаты
|
|
Employee |
Address |
Bill | New York |
John | Miami |
Steve | Chicago |
Пример 4
Employees:
Load * inline [
Employee|ID|Salary
Bill|001|20000
John|002|30000
Steve|003|35000
] (delimiter is '|');
Citizens:
Load * inline [
Employee|Address
Bill|New York
Mary|London
Steve|Chicago
Lucy|Madrid
Lucy|Paris
John|Miami
] (delimiter is '|') where not Exists (Employee);
Drop Tables Employees;
Предложение where, включая not: where not Exists (Employee).
Это означает, что в новую таблицу загружаются только имена из таблицы Citizens, отсутствующие в таблице Employees.
Обратите внимание, что для Lucy в таблице Citizens имеются два значения, однако в результирующую таблицу включается только одно из них. При загрузке первой строки значение Lucy включается в поле Employee. Таким образом, в ходе проверки второй строки значение уже существует.
Результаты
Employee |
Address |
Mary |
London |
Lucy | Madrid |
Пример 5
Этот пример демонстрирует порядок загрузки всех значений.
Employees:
Load Employee As Name;
LOAD * inline [
Employee|ID|Salary
Bill|001|20000
John|002|30000
Steve|003|35000
] (delimiter is '|');
Citizens:
Load * inline [
Employee|Address
Bill|New York
Mary|London
Steve|Chicago
Lucy|Madrid
Lucy|Paris
John|Miami
] (delimiter is '|') where not Exists (Name, Employee);
Drop Tables Employees;
Чтобы получить все значения для Lucy, внесены два изменения:
-
В таблицу Employees была вставлена предшествующая загрузка, где Employee переименовано в Name.
Load Employee As Name;
-
Условие Where в Citizens изменено на:
not Exists (Name, Employee).
Это создает поля для Name и Employee. Когда проверяется вторая строка с Lucy, она еще не существует в Name.
Результаты
Employee |
Address |
Mary |
London |
Lucy | Madrid |
Lucy | Paris |