JSONiq - JSONiq

JSONiq
Парадигмадекларативный, функциональный, модульный
Печатная дисциплинадинамичный, сильный
Операционные системыКроссплатформенность
Расширения имени файла.jq, .jqy
Интернет сайтwww.jsoniq.org
Под влиянием
XQuery, SQL

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

JSONiq это открытая спецификация, опубликованная под Лицензия Creative Commons Attribution-ShareAlike 3.0 лицензия. Он основан на XQuery язык, с которым он использует те же основные выражения и операции с атомарными типами. JSONiq поставляется в двух синтаксических вариантах, которые изначально поддерживают JSON и XML.

  1. Синтаксис JSONiq (надмножество JSON) расширен за счет поддержки XML через совместимое подмножество XQuery.
  2. Синтаксис XQuery (собственная поддержка XML) расширен за счет поддержки JSON через совместимое подмножество (расширение JSONiq для XQuery) указанного выше синтаксиса JSONiq.

Функции

JSONiq в первую очередь предоставляет средства для извлечения и преобразования данных из документов JSON или любого источника данных, который можно рассматривать как JSON (например, реляционные базы данных или же веб-сервисы ).

Основным выражением для выполнения таких операций является SQL -подобно "FLWOR выражение », происходящее из XQuery. Выражение FLWOR состоит из пяти предложений, после которых оно названо: FOR, LET, WHERE, ORDER BY, RETURN. Однако он также поддерживает пункты для группировки и создания окон.

Язык также предоставляет синтаксис для создания новых документов JSON, в которых имена и значения полей известны заранее или могут быть вычислены динамически. Язык JSONiq (не расширение XQuery) является надмножеством JSON. То есть каждый документ JSON является действующей программой JSONiq.

Кроме того, язык также поддерживает синтаксис навигации для извлечения имен полей и значений из объектов JSON, а также значений из массивов JSON. Навигация устойчива при отсутствии значений или если значения неоднородны, поскольку она молча игнорирует непредвиденные значения, не вызывая ошибок.

Все конструкции определены как выражения в языке и могут быть произвольно вложены.

JSONiq не включает функции для обновления документов JSON или XML, не имеет возможностей полнотекстового поиска и не содержит операторов. Все эти функции находятся в стадии активной разработки для следующей версии языка.

JSONiq - это язык программирования, который может выражать произвольные преобразования JSON в JSON или XML в XML. Он также позволяет выполнять преобразования между JSON и XML. Все такие преобразования имеют следующие особенности:

  1. Логическая / физическая независимость данных
  2. Декларативная
  3. Высокий уровень
  4. Без побочных эффектов
  5. Строго типизированный

Модель данных

Язык основан на модели данных JSONiq (JDM), которая является расширением Модель данных XQuery и XPath (XDM). JDM использует древовидную модель информационного содержания документа JSON или XML. Он содержит объекты JSON, массивы JSON, все виды узлов XML, а также атомарные значения, такие как целые числа, строки или логические значения, все они определены в Схема XML.

JDM формирует основу для языка, ориентированного на наборы, в котором экземпляры модели данных представляют собой последовательности (одноэлементное значение считается последовательностью длины, равной единице). Элементы в последовательности могут быть объектами JSON, массивами JSON, узлами XML или атомарными значениями.

Примеры

В приведенном ниже примере кода JSONiq вычисляется код города и количество всех людей старше 20 лет из коллекции объектов JSON person (см. JSON статья для примера объекта).

 за $ p в коллекция("лица") куда $ за возраст gt 20 позволять $ домой := $ p.phoneNumber[][$$. тип экв "дома"].номер группа к $ area := подстрока перед ($ home, " ") возвращаться    {     "код города" : $ area,     "считать" : считать ($ p)   }

Все конструкции JSONiq являются выражениями и также могут содержаться в теле функции.

 объявить функция местный: взрослые() {   за $п в коллекция("лица")   куда $страница gt 20   возвращаться $п };

Следующий запрос преобразует части каждого объекта person в элемент XML с использованием синтаксиса XQuery (расширение JSONiq для XQuery).

 за $п в коллекция("лица") возвращаться    <person><firstName>{$п("имя")}</firstName><lastName>{$п("фамилия")}</lastName><age>{$п("возраст")}</age></person>

Приложения

Ниже приведены несколько примеров того, как и где можно использовать JSONiq:

  1. Извлечение информации из базы данных для использования в веб-сервисе.
  2. Создание сводных отчетов по данным, хранящимся в хранилище документов JSON.
  3. Выбор и преобразование данных JSON в XHTML для публикации в Интернете.
  4. Сопоставление данных из различных источников и форматов (например, хранилище документов JSON, база данных XML, реляционная база данных и веб-сервис) и предложение их в веб-сервисе.
  5. Преобразование коллекций объектов JSON в другую схему.

Сравнение двух синтаксических разновидностей

Существует два синтаксиса JSONiq, которые пользователи могут использовать в зависимости от того, ориентированы ли они на JSON или XML. Оба синтаксиса используют одну и ту же модель данных и очень похожи, за некоторыми исключениями.

Синтаксис JSONiq

Чистый синтаксис JSONiq - это надмножество JSON. Строго говоря, это не расширенный набор XQuery, хотя все его выражения и семантика доступны. Следующие аспекты синтаксиса JSONiq не соответствуют XQuery:

  1. Нет имен, содержащих точки.
  2. Нет . для элемента контекста (вместо него следует использовать $$).
  3. Никаких одинарных кавычек.
  4. JSON, экранирование на основе обратной косой черты в строковые литералы.
  5. Шаг оси не разрешен в начале выражения относительного пути.

Синтаксис XQuery с расширением JSONiq

Расширение JSONiq для XQuery - это надмножество XQuery, но не надмножество JSON. Он полностью соответствует и обратно совместим с рекомендациями кандидата XQuery 3.0. Следующие аспекты JSONiq не поддерживаются в синтаксисе XQuery.

  1. Нет поиска по объектам на основе точек (вместо этого $ object («ключ»)).
  2. Нет $$ для элемента контекста.
  3. XML, экранирование строковых литералов на основе амперсанда.
  4. Ключи объектов должны быть указаны в кавычках
  5. Нет литералов true / false / null
  6. Встроенные атомарные типы должны иметь префикс xs :.
  7. За неатомарными типами должны стоять круглые скобки.
  8. Пустая последовательность () должна быть записана как таковая.
  9. Нет поиска в массиве и нет [] распаковки массива.

дальнейшее чтение

  • JSONiq - SQL для NoSQL. Гислен Фурни. Независимая издательская платформа CreateSpace. ISBN  1489530371.

Реализации

Рекомендации