Перейти к основному содержимому Перейти к дополнительному содержимому

Load

Оператор LOAD загружает поля из файла, из определенных в скрипте данных, из ранее загруженной таблицы, из веб-страницы, из результата последующего оператора SELECT или путем создания данных.

Синтаксис:  

LOAD [ distinct ] fieldlist

[( from file [ format-spec ] |

from_field fieldassource [format-spec]

inline data [ format-spec ] |

resident table-label |

autogenerate size )]

[ where criterion | while criterion ]

[ group_by groupbyfieldlist ]

[order_by orderbyfieldlist ]

Аргументы:  

Аргументы Load
АргументОписание
distinct

Можно использовать distinct в качестве предиката, если только требуется загружать уникальные записи. Если имеются повторяющиеся записи, загружается первый экземпляр.

Если используются предшествующие загрузки, необходимо поместить distinct в первый оператор load, так как distinct затрагивает только таблицу назначения.

fieldlistfieldlist ::= ( * | field {, field } )

Список полей, которые необходимо загрузить. Символ * в качестве списка полей обозначает все поля таблицы.

field ::= ( fieldref | expression ) [as aliasname ]

Определение поля должно всегда содержать литерал, ссылку на существующее поле или выражение.

fieldref ::= ( fieldname |@fieldnumber |@startpos:endpos [ I | U | R | B | T] )

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

@fieldnumber представляет номер поля в табличном файле с разделителями. Он должен быть положительным целым числом с предшествующим символом «@». Нумерация всегда начинается с 1 и содержит число полей.

@startpos:endpos представляет начальную и конечную позиции поля в файле с записями фиксированной длины. Позиции должны быть положительными целыми числами. Двум числам должен предшествовать символ «@», и они должны быть разделены двоеточием. Нумерация всегда начинается с 1 и содержит число позиций. В последнем поле элемент n используется как конечная позиция.

  • Если после @startpos:endpos указаны символы I или U, прочитанные байты будут интерпретированы как двоичное целое число со знаком (I) или без знака (U) (порядок байтов Intel). Прочитанное число позиций должно быть 1, 2 или 4.
  • Если после @startpos:endpos указан символ R, прочитанные байты будут интерпретированы как двоичное действительное число (32-разрядное IEEE или 64-разрядное с плавающей запятой). Прочитанное число позиций должно быть 4 или 8.
  • Если после @startpos:endpos указан символ B, прочитанные байты будут интерпретироваться как числа в двоичной кодировке BCD (Binary Coded Decimal) в соответствии со стандартом COMP-3. Может быть указано любое число байтов.

expression может быть числовой или строковой функцией на основе одного или нескольких других полей в этой же таблице. Дополнительные сведения см. в справке по синтаксису выражений.

as используется для назначения полю нового имени.

from

from используется в случае, если данные должны быть загружены из файла.

file ::= [ path ] filename

  • абсолютный

    Пример: c:\data\

  • относительно пути документа QlikView.

    Пример: data\

  • URL-адрес (HTTP или FTP), указывающий на местоположение в Интернете или интрасети. URL-адрес должен быть представлен в кодировке URL, к примеру, в случае, если он содержит пробелы.

    Пример: http://www.qlik.com

    Пример: http://www.enterprise.com/project%20files (http://www.enterprise.com/project files)

Если путь отсутствует, приложение QlikView выполняет поиск файла в каталоге, указанном оператором Directory. Если оператор Directory отсутствует, приложение QlikView выполняет поиск в рабочем каталоге, который обычно является каталогом, в котором находится файл QlikView.

Примечание к информацииПри серверной установке QlikView рабочим каталогом по умолчанию является C:\ProgramData\QlikTech\Documents. Рабочий каталог по умолчанию можно изменить в Консоль управления QlikView.

Элемент filename может содержать стандартные знаки подстановки DOS ( * и ? ). В результате будут загружены все файлы в указанном каталоге, удовлетворяющие критериям.

format-spec ::= ( fspec-item { , fspec-item } )

Спецификация формата состоит из списка нескольких элементов спецификации формата, заключенных в скобки.

Directory

From

from_fieldfrom_field используется в случае, если данные должны быть загружены из ранее загруженного поля.

fieldassource::=(tablename, fieldname)

Поле — это имя ранее загруженных tablename и fieldname.

format-spec ::= ( fspec-item {, fspec-item } )

Спецификация формата состоит из списка нескольких элементов спецификации формата, заключенных в скобки.

inlineinline используется в случае, если данные должны быть введены в скрипте, а не загружены из файла.

data ::= [ text ]

Данные, введенные с использованием предложения inline, должны быть заключены в специальные символы: квадратные скобки, двойные кавычки или обратные кавычки. Текст между ними интерпретируется так же, как и содержимое файла. Поэтому при вставке новой строки в текстовый файл ее также необходимо вставить в текст предложения inline, нажав клавишу «Ввод» при вводе скрипта.

В простой встроенной загрузке количество столбцов определяется по первой строке.

format-spec ::= ( fspec-item {, fspec-item } )

Для настройки встроенной загрузки можно использовать многие из тех же элементов спецификации формата, которые доступны для других загруженных таблиц. Эти элементы перечислены в скобках. Для получения дополнительной информации см. раздел Элементы спецификации формата.

Для получения дополнительной информации о встроенных загрузках см. Загрузка данных из встроенных таблиц.

residentЭлемент resident используется в случае, если данные должны быть загружены из ранее загруженной таблицы.

table label — это метка, предшествующая оператору(-ам) LOAD или SELECT, используемым для создания исходной таблицы. В конце метки должно быть указано двоеточие.

При использовании сочетания операторов LOAD distinct и resident в версии QlikView 12.00 или более поздней версии порядок загрузки отличается от принятого в QlikView 11.20. Чтобы определить порядок загрузки, добавьте предложение order by.

Загрузка данных из ранее загруженной таблицы

Метки таблицы

autogenerateautogenerate используется в случае, если данные должны быть автоматически созданы программой QlikView.

size ::= number

Number — это целое число, обозначающее число создаваемых записей. Список полей не должно содержать выражения, для которых требуются данные из базы данных. В выражениях допускается использовать только константы и функции без параметров (такие как rand() или recno()).

extension

Можно загружать данные из аналитических подключений. Предложение extension можно использовать для вызова функции, определенной в подключаемом модуле серверного расширения (SSE), либо для оценки скрипта.

Если отправить одну таблицу в подключаемый модуль SSE, будет возвращена одна таблица данных. Если подключаемый модуль не указал имена возвращенных полей, полям будут присвоены имена начиная с Field1, Field2.

Extension pluginname.functionname( tabledescription );

  • Загрузка данных при помощи функции подключаемого модуля SSE

    tabledescription ::= (table { ,tablefield} )

    Если порядок полей таблицы не указан, поля будут использоваться в порядке загрузки.

  • Загрузка данных при помощи оценки скрипта в подключаемом модуле SSE

    tabledescription ::= ( script, table { ,tablefield} )

Типы данных в аналитических подключениях определяются автоматически. Если в составе данных отсутствуют числовые значения, однако содержится по крайней мере одна текстовая строка, отличная от NULL, поле считается текстовым. В противном случае поле считается числовым.

Тип данных можно установить принудительно. Для этого необходимо заключить имя поля в функцию String() или Mixed().

  • Если используется функция String(), значение поля рассматривается как текстовое. Если поле является числовым, текстовая часть двойного значения извлекается без выполнения преобразования.
  • Если используется функция Mixed(), значение поля рассматривается как двойное.

Использование функций String() или Mixed() вне определений поля таблицы extension не поддерживается, как не поддерживается использование других функций QlikView в определении поля таблицы.

Для получения инструкций по созданию аналитического подключения в QlikView Server или QlikView Desktop см. раздел Аналитические подключения.

Ознакомиться с подробными сведениями об аналитических подключениях можно в репозитории GitHub. qlik-oss/server-side-extension

wherewhere — предложение, которое используется для указания того, нужно ли включить запись в выборку или нет. Выборка включается, если элемент criterion имеет значение True.

criterion — это логическое выражение.

while

while — это предложение, используемое для указания необходимости повторного чтения записи. Эта же запись читается, если для элемента criterion указано значение True. Чтобы быть полезным, предложение while обычно должно содержать функцию IterNo( ).

criterion — это логическое выражение.

group_by

group by — это выражение, используемое для определения полей данных для агрегирования (группировки). Поля агрегирования должны быть включены таким же образом в загруженные выражения. Вне функций агрегирования в загруженных выражениях могут использоваться только поля агрегирования.

groupbyfieldlist ::= (fieldname { ,fieldname } )

order_byorder by — это предложение, используемое для сортировки записей резидентной таблицы до их обработки оператором load. Резидентная таблица может быть отсортирована по одному или нескольким полям в возрастающем или убывающем порядке. Сортировка осуществляется первично по числовому значению и дополнительно в порядке соответствия национальных параметров. Это предложение может использоваться, только если источником данных является резидентная таблица.

Поля упорядочения указывают поле для сортировки резидентной таблицы. Поле может быть указано по имени или по числу в резидентной таблице (первое поле имеет номер 1).

orderbyfieldlist ::= fieldname [ sortorder ] { , fieldname [ sortorder ] }

sortorder имеет значение asc для сортировки по возрастанию или desc для сортировки по убыванию. Если sortorder не указан, используется asc.

fieldname, path, filename и aliasname — это текстовые строки, представляющие подразумеваемые соответствующие имена. Любое поле в исходной таблице может использоваться в качестве fieldname. Однако поля, созданные с помощью выражения (aliasname), не рассматриваются и не могут использоваться внутри одного оператора load.

Если источник данных не указан с помощью предложений from, inline, resident, from_field или autogenerate, данные будут загружены из результата сразу после выполнения оператора SELECT или LOAD. Последующий оператор не должен иметь префикс.

Предшествующий оператор LOAD

Примеры:  

Помогла ли вам эта страница?

Если вы обнаружили какую-либо проблему на этой странице и с ее содержанием — будь то опечатка, пропущенный шаг или техническая ошибка, сообщите нам об этом, чтобы мы смогли ее исправить!

Присоединяйтесь к программе модернизации аналитики

Remove banner from view

Модернизируйте ваши важные приложения QlikView без ущерба с помощью программы модернизации аналитики. Щелкните здесь для получения дополнительной информации или свяжитесь с нами: ampquestions@qlik.com