<?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=DB.Compute</id>
	<title>DB.Compute - Revision history</title>
	<link rel="self" type="application/atom+xml" href="http://sfsys.ru/index.php?action=history&amp;feed=atom&amp;title=DB.Compute"/>
	<link rel="alternate" type="text/html" href="http://sfsys.ru/index.php?title=DB.Compute&amp;action=history"/>
	<updated>2026-04-04T11:25:30Z</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=DB.Compute&amp;diff=342&amp;oldid=prev</id>
		<title>Admin: 1 revision imported</title>
		<link rel="alternate" type="text/html" href="http://sfsys.ru/index.php?title=DB.Compute&amp;diff=342&amp;oldid=prev"/>
		<updated>2021-02-07T06:43:16Z</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:43, 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=DB.Compute&amp;diff=341&amp;oldid=prev</id>
		<title>Admin at 12:59, 18 September 2019</title>
		<link rel="alternate" type="text/html" href="http://sfsys.ru/index.php?title=DB.Compute&amp;diff=341&amp;oldid=prev"/>
		<updated>2019-09-18T12:59:45Z</updated>

		<summary type="html">&lt;p&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=Compute&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;
Функция производит выборку с агрегацией по таблице объектов текущего вида с помощью указанных фильтров. Результат выборки возвращается в виде таблицы значений со столбцами группировки и агрегации. Функция может быть выполнена для объектов типа ''справочник'', ''документ'', ''журнал'' и ''накопитель''. В таблице-результате присутствуют следующие столбцы:&lt;br /&gt;
* Столбцы реквизитов группировки, наименования совпадают с наименованиями реквизитов.&lt;br /&gt;
* Столбцы агрегации. Наименования эти столбцов создаются в виде '''_&amp;lt;Тип операции агрегации&amp;gt;_&amp;lt;Наименование реквизита агрегации&amp;gt;'''. К примеру, для реквизита агрегации ''Сумма:SUM'' будет создан столбец ''_SUM_Сумма''.&lt;br /&gt;
&lt;br /&gt;
== Синтаксис ==&lt;br /&gt;
&amp;lt;code&amp;gt;&lt;br /&gt;
{{Grey|DB.}}'''Compute'''(''&amp;lt;Список реквизитов группировки (STRING)&amp;gt;'',''&amp;lt;Список реквизитов агрегации с типами операций (STRING)&amp;gt;''{{Optional|,&amp;lt;Стандарные фильтры&amp;gt;...}}):''&amp;lt;Результат вычисления (TAB)&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; - Аргумент перечисляет наименования реквизитов группировки, разделенных запятыми. Каждый из реквизитов должен присутствовать в оригинальном объекте.&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;Вид операции агрегации&amp;gt;]&amp;lt;/code&amp;gt;. По умолчанию выполняется операция ''SUM''. Допустимые виды операции агрегации:&lt;br /&gt;
** '''SUM''' (по умолчанию) -- найти суммы реквизита агрегации в требуемых разрезах&lt;br /&gt;
** '''COUNT''' -- подсчитать количество записей, участвовавших в агрегации записи-результата&lt;br /&gt;
** '''AVG''' -- найти средние значения реквизита агрегации в требуемых разрезах&lt;br /&gt;
** '''MAX''' -- найти максимальное значения реквизита агрегации в требуемых разрезах&lt;br /&gt;
** '''MIN''' -- найти минимальное значения реквизита агрегации в требуемых разрезах&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;
Возвращается таблица, результат запроса по агрегации.&lt;br /&gt;
&lt;br /&gt;
== Примеры ==&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
//Фрагмент находит максимальное значение реквизита Идентификатор документа Задание и создает новое уникальное значение в текущем документе aEl&lt;br /&gt;
//Для уверенности в уникальности нового значения, до его создания будет осуществлена блокировка серверного семафора &amp;quot;СозданиеИдентификатораЗадания&amp;quot;&lt;br /&gt;
While not DBLockStringMutex(&amp;quot;СозданиеИдентификатораЗадания&amp;quot;) Do&lt;br /&gt;
  Sleep(10);&lt;br /&gt;
EndDo;&lt;br /&gt;
Try&lt;br /&gt;
  Ном:=0;&lt;br /&gt;
  аДок:=Doc.Задание;&lt;br /&gt;
  aTab:=аДок.Compute(&amp;quot;&amp;quot;,&amp;quot;Идентификатор:MAX&amp;quot;,&amp;quot;&amp;lt;DocDate,&amp;gt;=DocDate&amp;quot;,BegOfDay(aEl.DocDate+1),BegOfDay(aEl.DocDate));&lt;br /&gt;
  If aTab.Size()&amp;gt;0 Then&lt;br /&gt;
    //Получаем текущее максимальное значение реквизита&lt;br /&gt;
    Ном:=Number(aTab.Get(1,&amp;quot;_MAX_Идентификатор&amp;quot;));&lt;br /&gt;
  EndIf;&lt;br /&gt;
  //Увеличиваем значение и сохраняем в текущем документе&lt;br /&gt;
  aEl.Идентификатор:=Min(Ном+1,9999);&lt;br /&gt;
  aEl.Save();&lt;br /&gt;
Finally&lt;br /&gt;
  DBUnlockStringMutex(&amp;quot;СозданиеИдентификатораЗадания&amp;quot;);&lt;br /&gt;
EndTry&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>
		
	</entry>
</feed>