<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>http://sfsys.ru/index.php?action=history&amp;feed=atom&amp;title=TempDB.UpdateFromGroups</id>
	<title>TempDB.UpdateFromGroups - Revision history</title>
	<link rel="self" type="application/atom+xml" href="http://sfsys.ru/index.php?action=history&amp;feed=atom&amp;title=TempDB.UpdateFromGroups"/>
	<link rel="alternate" type="text/html" href="http://sfsys.ru/index.php?title=TempDB.UpdateFromGroups&amp;action=history"/>
	<updated>2026-04-04T15:27:26Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.31.1</generator>
	<entry>
		<id>http://sfsys.ru/index.php?title=TempDB.UpdateFromGroups&amp;diff=3930&amp;oldid=prev</id>
		<title>Admin: 1 revision imported</title>
		<link rel="alternate" type="text/html" href="http://sfsys.ru/index.php?title=TempDB.UpdateFromGroups&amp;diff=3930&amp;oldid=prev"/>
		<updated>2021-06-28T07:05:22Z</updated>

		<summary type="html">&lt;p&gt;1 revision imported&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;en&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;← Older revision&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;Revision as of 07:05, 28 June 2021&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-notice&quot; lang=&quot;en&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(No difference)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
		<author><name>Admin</name></author>
		
	</entry>
	<entry>
		<id>http://sfsys.ru/index.php?title=TempDB.UpdateFromGroups&amp;diff=3929&amp;oldid=prev</id>
		<title>1&gt;Admin: /* Аргументы */</title>
		<link rel="alternate" type="text/html" href="http://sfsys.ru/index.php?title=TempDB.UpdateFromGroups&amp;diff=3929&amp;oldid=prev"/>
		<updated>2021-04-23T08:23:58Z</updated>

		<summary type="html">&lt;p&gt;‎&lt;span dir=&quot;auto&quot;&gt;&lt;span class=&quot;autocomment&quot;&gt;Аргументы&lt;/span&gt;&lt;/span&gt;&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;en&quot;&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;← Older revision&lt;/td&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;Revision as of 08:23, 23 April 2021&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l36&quot; &gt;Line 36:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Line 36:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;* &amp;lt;code&amp;gt;''&amp;lt;Условие для определения строк группировки (STRING)&amp;gt;''&amp;lt;/code&amp;gt; - Аргумент задает условие на языке запросов (см. [[Временная таблица базы данных#Формулы при вычислении полей записей временной таблицы базы данных|Временная таблица базы данных]]). При обходе записей таблицы, записи, для которых условие выполнено, будут считаться записями группировки, если условие не выполняется, запись считается подчиненной записью и значения столбцов из аргумента 3 будут заполнены из записи предыдущей группировки.&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;* &amp;lt;code&amp;gt;''&amp;lt;Условие для определения строк группировки (STRING)&amp;gt;''&amp;lt;/code&amp;gt; - Аргумент задает условие на языке запросов (см. [[Временная таблица базы данных#Формулы при вычислении полей записей временной таблицы базы данных|Временная таблица базы данных]]). При обходе записей таблицы, записи, для которых условие выполнено, будут считаться записями группировки, если условие не выполняется, запись считается подчиненной записью и значения столбцов из аргумента 3 будут заполнены из записи предыдущей группировки.&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;* &amp;lt;code&amp;gt;''&amp;lt;Наименования столбцов сортировки с направлением сортировки (STRING)&amp;gt;''&amp;lt;/code&amp;gt; - Задает наименования столбцов для последовательности сортировки через запятую. Формат задания столбца: &amp;lt;code&amp;gt;&amp;lt;Наименование столбца&amp;gt;{+,-}&amp;lt;/code&amp;gt;, если оба знака направления ''+'' или ''-'' опущены, будет использована сортировка по неубыванию (''+''). Вне зависимости от наличия или отсутствия указания на столбцы сортировки при обходе таблицы, система всегда использует последнюю сортировку по уникальному индексу записи '''@ID'''.&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;* &amp;lt;code&amp;gt;''&amp;lt;Наименования столбцов сортировки с направлением сортировки (STRING)&amp;gt;''&amp;lt;/code&amp;gt; - Задает наименования столбцов для последовательности сортировки через запятую. Формат задания столбца: &amp;lt;code&amp;gt;&amp;lt;Наименование столбца&amp;gt;{+,-}&amp;lt;/code&amp;gt;, если оба знака направления ''+'' или ''-'' опущены, будет использована сортировка по неубыванию (''+''). Вне зависимости от наличия или отсутствия указания на столбцы сортировки при обходе таблицы, система всегда использует последнюю сортировку по уникальному индексу записи '''@ID'''.&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;−&lt;/td&gt;&lt;td style=&quot;color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;* &amp;lt;code&amp;gt;''&amp;lt;Стандартные фильтры&amp;gt;''&amp;lt;/code&amp;gt; - {{Optional}} Стандартные фильтры отбора записей текущей таблицы данных описаны в статье [[Стандартные фильтры]]. Важное отличие от фильтров функций объектов базы данных заключается в том, стандартные фильтры всегда работают в сложном (расширенном) режиме, при этом отсутствует требование, что первая строка фильтра должна начинаться на знак '''~'''. Выражения фильтров содержат весь возможный набор функций и операторов языка запросов (см. [[Временная таблица базы данных]], [[Объект запрос базы данных]]), при указании наименование также применимы префиксы (типа ''':'''), как это описано в [[Временная таблица базы данных#Формулы при вычислении полей записей временной таблицы базы данных|статье по временной таблице базы данных]]. Записи таблицы, не входящие в фильтр, будут пропущены при изменении.&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;+&lt;/td&gt;&lt;td style=&quot;color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;* &amp;lt;code&amp;gt;''&amp;lt;Стандартные фильтры&amp;gt;''&amp;lt;/code&amp;gt; - {{Optional}} Стандартные фильтры отбора записей текущей таблицы данных описаны в статье [[Стандартные фильтры]]. Важное отличие от фильтров функций объектов базы данных заключается в том, &lt;ins class=&quot;diffchange diffchange-inline&quot;&gt;что &lt;/ins&gt;стандартные фильтры всегда работают в сложном (расширенном) режиме, при этом отсутствует требование, что первая строка фильтра должна начинаться на знак '''~'''. Выражения фильтров содержат весь возможный набор функций и операторов языка запросов (см. [[Временная таблица базы данных]], [[Объект запрос базы данных]]), при указании наименование также применимы префиксы (типа ''':'''), как это описано в [[Временная таблица базы данных#Формулы при вычислении полей записей временной таблицы базы данных|статье по временной таблице базы данных]]. Записи таблицы, не входящие в фильтр, будут пропущены при изменении.&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;== Примеры ==&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;== Примеры ==&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;/table&gt;</summary>
		<author><name>1&gt;Admin</name></author>
		
	</entry>
	<entry>
		<id>http://sfsys.ru/index.php?title=TempDB.UpdateFromGroups&amp;diff=2914&amp;oldid=prev</id>
		<title>Admin: 1 revision imported</title>
		<link rel="alternate" type="text/html" href="http://sfsys.ru/index.php?title=TempDB.UpdateFromGroups&amp;diff=2914&amp;oldid=prev"/>
		<updated>2021-02-07T06:54:43Z</updated>

		<summary type="html">&lt;p&gt;1 revision imported&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;en&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;← Older revision&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;Revision as of 06:54, 7 February 2021&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-notice&quot; lang=&quot;en&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(No difference)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
		<author><name>Admin</name></author>
		
	</entry>
	<entry>
		<id>http://sfsys.ru/index.php?title=TempDB.UpdateFromGroups&amp;diff=2913&amp;oldid=prev</id>
		<title>Admin: /* Примеры */</title>
		<link rel="alternate" type="text/html" href="http://sfsys.ru/index.php?title=TempDB.UpdateFromGroups&amp;diff=2913&amp;oldid=prev"/>
		<updated>2020-09-26T07:37:46Z</updated>

		<summary type="html">&lt;p&gt;‎&lt;span dir=&quot;auto&quot;&gt;&lt;span class=&quot;autocomment&quot;&gt;Примеры&lt;/span&gt;&lt;/span&gt;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;{{infobox function&lt;br /&gt;
|name=UpdateFromGroups&lt;br /&gt;
|object=[[Временная таблица базы данных]]&lt;br /&gt;
|caption=Заполнение подчиненных записей&lt;br /&gt;
|type=1&lt;br /&gt;
|status=2&lt;br /&gt;
|db=2&lt;br /&gt;
|exception=Невозможно превратить в строку, неверные наименования столбцов, неверные аргументы, ошибка сервера&lt;br /&gt;
|visual=0}}&lt;br /&gt;
{{HeadLinks|&lt;br /&gt;
* [[Main_Page|Начальная страница]]&lt;br /&gt;
* [[Общее_описание_языка|Общее описание]]&lt;br /&gt;
* [[Объекты]]&lt;br /&gt;
* [[Временная таблица базы данных]]}}&lt;br /&gt;
Функция выполняет заполнение обычных столбцов значениями столбцов группировки. Функция используется, при загрузке из сложных строчных частей с промежуточными группировками или подобных случаев. При обходе записей таблицы, записи, для которых условие аргумента 1 выполнено, будут считаться записями группировки, если условие не выполняется, запись считается подчиненной записью и значения столбцов из аргумента 3 будут заполнены из записи предыдущей группировки. Выполнение функции может занимать продолжительное время, так как серверы базы данных (типа SQL) не имеют функционала для выполнения таких операции с помощью функций, оперирующих наборами записей. Пример сортировки таблицы с тремя столбцами:&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
Sort GroupID Value       Sort GroupID  Value&lt;br /&gt;
 11    1      5           11    1      5&lt;br /&gt;
 22    0      ?           22    0      5&lt;br /&gt;
 33    0      ?           33    0      5 &lt;br /&gt;
 34    0      ?      -&amp;gt;   34    0      5&lt;br /&gt;
 35    2      17          35    2      17&lt;br /&gt;
 37    0      ?           37    0      17&lt;br /&gt;
 80    0      ?           80    0      17&lt;br /&gt;
 81    0      ?           81    0      17&lt;br /&gt;
&lt;br /&gt;
При выполнении функции UpdateFromGroups(&amp;quot;GroupID&amp;lt;&amp;gt;0&amp;quot;,&amp;quot;Sort+&amp;quot;,&amp;quot;Value&amp;quot;) над первой таблицей, получается вторая таблица. Содержимое значений столбцов, помеченных &amp;quot;?&amp;quot;, не имеет значения.&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== Синтаксис ==&lt;br /&gt;
&amp;lt;code&amp;gt;&lt;br /&gt;
{{Grey|TempDB.}}'''UpdateFromGroups'''(''&amp;lt;Условие для определения строк группировки (STRING)&amp;gt;'',''&amp;lt;Наименования столбцов сортировки с направлением сортировки (STRING)&amp;gt;'',''&amp;lt;Наименования заполняемых столбцов (STRING)&amp;gt;''{{Optional|,&amp;lt;Стандартные фильтры&amp;gt;...}})&lt;br /&gt;
&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==== Аргументы ====&lt;br /&gt;
* &amp;lt;code&amp;gt;''&amp;lt;Условие для определения строк группировки (STRING)&amp;gt;''&amp;lt;/code&amp;gt; - Аргумент задает условие на языке запросов (см. [[Временная таблица базы данных#Формулы при вычислении полей записей временной таблицы базы данных|Временная таблица базы данных]]). При обходе записей таблицы, записи, для которых условие выполнено, будут считаться записями группировки, если условие не выполняется, запись считается подчиненной записью и значения столбцов из аргумента 3 будут заполнены из записи предыдущей группировки.&lt;br /&gt;
* &amp;lt;code&amp;gt;''&amp;lt;Наименования столбцов сортировки с направлением сортировки (STRING)&amp;gt;''&amp;lt;/code&amp;gt; - Задает наименования столбцов для последовательности сортировки через запятую. Формат задания столбца: &amp;lt;code&amp;gt;&amp;lt;Наименование столбца&amp;gt;{+,-}&amp;lt;/code&amp;gt;, если оба знака направления ''+'' или ''-'' опущены, будет использована сортировка по неубыванию (''+''). Вне зависимости от наличия или отсутствия указания на столбцы сортировки при обходе таблицы, система всегда использует последнюю сортировку по уникальному индексу записи '''@ID'''.&lt;br /&gt;
* &amp;lt;code&amp;gt;''&amp;lt;Стандартные фильтры&amp;gt;''&amp;lt;/code&amp;gt; - {{Optional}} Стандартные фильтры отбора записей текущей таблицы данных описаны в статье [[Стандартные фильтры]]. Важное отличие от фильтров функций объектов базы данных заключается в том, стандартные фильтры всегда работают в сложном (расширенном) режиме, при этом отсутствует требование, что первая строка фильтра должна начинаться на знак '''~'''. Выражения фильтров содержат весь возможный набор функций и операторов языка запросов (см. [[Временная таблица базы данных]], [[Объект запрос базы данных]]), при указании наименование также применимы префиксы (типа ''':'''), как это описано в [[Временная таблица базы данных#Формулы при вычислении полей записей временной таблицы базы данных|статье по временной таблице базы данных]]. Записи таблицы, не входящие в фильтр, будут пропущены при изменении.&lt;br /&gt;
&lt;br /&gt;
== Примеры ==&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
//Показан код примера, приведенного в описании функции&lt;br /&gt;
aTab:=Tab.Create(&amp;quot;Sort,GroupID,Value&amp;quot;);&lt;br /&gt;
aTab.AddLine(&amp;quot;Sort,GroupID,Value&amp;quot;,11,1,5);&lt;br /&gt;
aTab.AddLine(&amp;quot;Sort,GroupID,Value&amp;quot;,22,0,33);&lt;br /&gt;
aTab.AddLine(&amp;quot;Sort,GroupID,Value&amp;quot;,33,0,77);&lt;br /&gt;
aTab.AddLine(&amp;quot;Sort,GroupID,Value&amp;quot;,34,0,534);&lt;br /&gt;
aTab.AddLine(&amp;quot;Sort,GroupID,Value&amp;quot;,35,2,17);&lt;br /&gt;
aTab.AddLine(&amp;quot;Sort,GroupID,Value&amp;quot;,37,0,0);&lt;br /&gt;
aTab.AddLine(&amp;quot;Sort,GroupID,Value&amp;quot;,80,0,1);&lt;br /&gt;
aTab.AddLine(&amp;quot;Sort,GroupID,Value&amp;quot;,81,0,-10);&lt;br /&gt;
&lt;br /&gt;
//Создание и загрузка таблицы&lt;br /&gt;
aTemp:=TempDB.Create(&amp;quot;Sort:INT,GroupID:INT,Value:INT&amp;quot;);&lt;br /&gt;
aTemp.CopyFrom(aTab,&amp;quot;Sort,GroupID,Value&amp;quot;);&lt;br /&gt;
&lt;br /&gt;
//Преобразование значений столбца Value&lt;br /&gt;
aTemp.UpdateFromGroups(&amp;quot;GroupID&amp;lt;&amp;gt;0&amp;quot;,&amp;quot;Sort+&amp;quot;,&amp;quot;Value&amp;quot;);&lt;br /&gt;
&lt;br /&gt;
Message(&amp;quot;Sort; GroupID; Value&amp;quot;);&lt;br /&gt;
aTemp.Select();&lt;br /&gt;
While aTemp.Next() Do&lt;br /&gt;
  Message(&amp;quot;&amp;quot;+aTemp.Sort+&amp;quot;; &amp;quot;+aTemp.GroupID+&amp;quot;; &amp;quot;+aTemp.Value);&lt;br /&gt;
EndDo;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>
		
	</entry>
</feed>