Пример 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 |