Load
В контексте модификации диаграммы оператор LOAD загружает в гиперкуб дополнительные данные из данных, определенных в скрипте, или из предварительно загруженной таблицы. Также можно загружать данные из аналитических подключений.
Синтаксис:
Add | Replace LOAD fieldlist
(
inline data [ format-spec ] |
resident table-label
) | extension pluginname.functionname([script] tabledescription)]
[ where criterion | while criterion ]
[ group by groupbyfieldlist ]
[order by orderbyfieldlist ]
Аргументы:
Аргумент | Описание |
---|---|
fieldlist | fieldlist ::= ( * | field{, * | field } ) Список полей, которые необходимо загрузить. Символ * в качестве списка полей обозначает все поля таблицы. field ::= ( fieldref | expression ) [as aliasname ]Определение поля должно всегда содержать литерал, ссылку на существующее поле или выражение. fieldref ::= ( fieldname |@fieldnumber |@startpos:endpos [ I | U | R | B | T] )fieldname — это текст, идентичный имени поля в таблице. Обратите внимание, что для указания имени поля необходимо заключить его в прямые двойные кавычки или квадратные скобки, если имя содержит пробелы. Иногда имена полей явно недоступны. В таких случаях используется другая нотация: @fieldnumber представляет номер поля в табличном файле с разделителями. Он должен быть положительным целым числом с предшествующим символом «@». Нумерация всегда начинается с 1 и идет до числа полей. @startpos:endpos представляет начальную и конечную позиции поля в файле с записями фиксированной длины. Позиции должны быть положительными целыми числами. Двум числам должен предшествовать символ «@», и они должны быть разделены двоеточием. Нумерация всегда начинается с 1 и содержит число позиций. В последнем поле элемент n используется как конечная позиция.
expression может быть числовой или строковой функцией на основе одного или нескольких других полей в этой же таблице. Дополнительные сведения см. в справке по синтаксису выражений. |
inline | inline используется в случае, если данные должны быть введены в скрипте, а не загружены из файла. data ::= [ text ] Данные, введенные с использованием предложения inline, должны быть заключены в двойные или в квадратные скобки. Текст между ними интерпретируется так же, как и содержимое файла. Поэтому при вставке новой строки в текстовый файл ее также необходимо вставить в текст предложения inline, например, нажав клавишу Enter при вводе скрипта. Количество столбцов определяется по первой строке. format-spec ::= ( fspec-item {, fspec-item } )Спецификация формата состоит из списка нескольких элементов спецификации формата, заключенных в скобки. Для получения дополнительной информации см. раздел Элементы спецификации формата. |
resident | Элемент resident используется в случае, если данные должны быть загружены из ранее загруженной таблицы. table label — это метка, предшествующая оператору LOAD, используемому для создания исходной таблицы. В конце метки должно быть указано двоеточие. |
extension | Можно загружать данные из аналитических подключений. Предложение extension можно использовать для вызова функции, определенной в подключаемом модуле серверного расширения (SSE), либо для оценки скрипта. Если отправить одну таблицу в подключаемый модуль SSE, будет возвращена одна таблица данных. Если подключаемый модуль не указал имена возвращенных полей, полям будут присвоены имена начиная с Field1, Field2. Extension pluginname.functionname( tabledescription );
Обработка типов данных в определении поля таблицы Типы данных в аналитических подключениях определяются автоматически. Если в составе данных отсутствуют числовые значения, однако содержится по крайней мере одна текстовая строка, отличная от NULL, поле считается текстовым. В противном случае поле считается числовым. Тип данных можно установить принудительно. Для этого необходимо заключить имя поля в функцию String() или Mixed().
Использование функций String() или Mixed() вне определений поля таблицы extension не поддерживается, как не поддерживается использование других функций Qlik Sense в определении поля таблицы. Ознакомиться с подробными сведениями об аналитических подключениях можно в репозитории GitHub. qlik-oss/server-side-extension |
where | where — предложение, которое используется для указания того, нужно ли включить запись в выборку или нет. Выборка включается, если элемент criterion имеет значение True. criterion — это логическое выражение. |
while | while — это предложение, используемое для указания необходимости повторного чтения записи. Эта же запись читается, если для элемента criterion указано значение True. Чтобы быть полезным, предложение while обычно должно содержать функцию IterNo( ). criterion — это логическое выражение. |
group by | group by — это выражение, используемое для определения полей данных для агрегирования (группировки). Поля агрегирования должны быть включены таким же образом в загруженные выражения. Вне функций агрегирования в загруженных выражениях могут использоваться только поля агрегирования. groupbyfieldlist ::= (fieldname { ,fieldname } ) |
order by | order by — это предложение, используемое для сортировки записей резидентной таблицы до их обработки оператором load. Резидентная таблица может быть отсортирована по одному или нескольким полям в возрастающем или убывающем порядке. Сортировка осуществляется первично по числовому значению и дополнительно в порядке соответствия национальных параметров. Это предложение может использоваться, только если источником данных является резидентная таблица. Поля упорядочения указывают поле для сортировки резидентной таблицы. Поле может быть указано по имени или по числу в резидентной таблице (первое поле имеет номер 1). orderbyfieldlist ::= fieldname [ sortorder ] { , fieldname [ sortorder ] } sortorder имеет значение asc для сортировки по возрастанию или desc для сортировки по убыванию. Если sortorder не указан, используется asc. fieldname, path, filename и aliasname — это текстовые строки, представляющие подразумеваемые соответствующие имена. Любое поле в исходной таблице может использоваться в качестве fieldname. Однако поля, созданные с помощью предложения (aliasname), не рассматриваются и не могут использоваться внутри одного оператора load. |