Jump to content

ФЛВОР

Язык программирования XQuery определяет FLWOR (произносится как «цветок») как выражение, поддерживающее итерацию и привязку переменных к промежуточным результатам. FLWOR — это аббревиатура: FOR , LET , WHERE, ORDER BY, RETURN. [1] FLWOR во многом аналогичен оператору SQL SELECT -FROM-WHERE и может использоваться для обеспечения функций соединения с документами XML .

  • for создает последовательность узлов
  • let связывает последовательность с переменной
  • где фильтрует узлы логического выражения
  • упорядочить по сортировке узлов
  • return оценивается один раз для каждого узла
   for $d in doc("depts.xml")//deptno
   let $e := doc("emps.xml")//employee[deptno = $d]
   where count($e) >= 10
   order by avg($e/salary) descending
   return
     <big-dept>
        { $d,
           <headcount>{count($e)}</headcount>,
           <avgsal>{avg($e/salary)}</avgsal>
        }
     </big-dept>

В первом столбце запроса XQuery показаны ключевые слова for , let , where , order by и return парадигмы FLWOR. На простом английском языке это можно прочитать так : «Получить все отделы, в которых работает более десяти сотрудников, упорядочить эти отделы по уменьшению средней зарплаты и вернуть отчет о номерах отделов, численности сотрудников и средней зарплате в каждом большом отделе» . Результат может выглядеть так:

<big-dept>
    <deptno>17</deptno>
    <headcount>25</headcount>
    <avgsal>12500</avgsal>
</big-dept>
<big-dept>
    <deptno>24</deptno>
    <headcount>18</headcount>
    <avgsal>11327</avgsal>
</big-dept>
<big-dept>
    <deptno>3</deptno>
    <headcount>32</headcount>
    <avgsal>10725</avgsal>
</big-dept>

Пример использования Microsoft SQL Server

[ редактировать ]
DECLARE @xml XML

SET @xml = 
'<root_element>
	<branch_element>
		<item_1>42</item_1>
		<item_2>27</item_2>
	</branch_element>
	<branch_element>
		<item_1>a</item_1>
		<item_2>b</item_2>
	</branch_element>
</root_element>'

SELECT 
		x.y.query('for $s in self::node() return $s//item_1/text()') as i,
		x.y.query('for $s in self::node() return $s//item_2/text()') as j
	FROM @xml.nodes('/root_element') AS x(y);
  1. ^ Уолмсли, Присцилла (2007). XQuery . Севастополь, Калифорния, США: O'Reilly Media. Мистер. 73. ИСБН  978-0-596-00634-1 .
[ редактировать ]


Arc.Ask3.Ru: конец переведенного документа.
Arc.Ask3.Ru
Номер скриншота №: e4150da341ac4fc5041e4199f4b04f3b__1713751380
URL1:https://arc.ask3.ru/arc/aa/e4/3b/e4150da341ac4fc5041e4199f4b04f3b.html
Заголовок, (Title) документа по адресу, URL1:
FLWOR - Wikipedia
Данный printscreen веб страницы (снимок веб страницы, скриншот веб страницы), визуально-программная копия документа расположенного по адресу URL1 и сохраненная в файл, имеет: квалифицированную, усовершенствованную (подтверждены: метки времени, валидность сертификата), открепленную ЭЦП (приложена к данному файлу), что может быть использовано для подтверждения содержания и факта существования документа в этот момент времени. Права на данный скриншот принадлежат администрации Ask3.ru, использование в качестве доказательства только с письменного разрешения правообладателя скриншота. Администрация Ask3.ru не несет ответственности за информацию размещенную на данном скриншоте. Права на прочие зарегистрированные элементы любого права, изображенные на снимках принадлежат их владельцам. Качество перевода предоставляется как есть. Любые претензии, иски не могут быть предъявлены. Если вы не согласны с любым пунктом перечисленным выше, вы не можете использовать данный сайт и информация размещенную на нем (сайте/странице), немедленно покиньте данный сайт. В случае нарушения любого пункта перечисленного выше, штраф 55! (Пятьдесят пять факториал, Денежную единицу (имеющую самостоятельную стоимость) можете выбрать самостоятельно, выплаичвается товарами в течение 7 дней с момента нарушения.)