<?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=MassLoadObjects</id>
	<title>MassLoadObjects - Revision history</title>
	<link rel="self" type="application/atom+xml" href="http://sfsys.ru/index.php?action=history&amp;feed=atom&amp;title=MassLoadObjects"/>
	<link rel="alternate" type="text/html" href="http://sfsys.ru/index.php?title=MassLoadObjects&amp;action=history"/>
	<updated>2026-04-04T09:47:42Z</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=MassLoadObjects&amp;diff=1518&amp;oldid=prev</id>
		<title>Admin: 1 revision imported</title>
		<link rel="alternate" type="text/html" href="http://sfsys.ru/index.php?title=MassLoadObjects&amp;diff=1518&amp;oldid=prev"/>
		<updated>2021-02-07T06:51:47Z</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:51, 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=MassLoadObjects&amp;diff=1517&amp;oldid=prev</id>
		<title>Admin at 16:41, 6 January 2021</title>
		<link rel="alternate" type="text/html" href="http://sfsys.ru/index.php?title=MassLoadObjects&amp;diff=1517&amp;oldid=prev"/>
		<updated>2021-01-06T16:41:38Z</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=MassLoadObjects&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;
Функция производит загрузку произвольного количества объектов из списка, таблицы или являющихся реквизитами объекта БД, одновременно, что быстрее, чем загрузка этих объектов последовательно один за другим. Дополнительные параметры позволяют настроить загрузку, в т.ч. ограничить ее загрузкой только заголовков. Попадающие в выборку объекты, не являющиеся объектами базы данных, будут пропущены, также будут пропущены уже загруженные объекты. Функции разрешено передавать смешанные объекты, принадлежащие [[ExternalDBase.Connect|разным базам данных]]. Функция гарантирует всего один запрос к серверу (сервер может создать множество запросов к базе данных) на один вызов, это может ускорить работу в сетях с низкой скоростью ответа (''latency''), к примеру в Интернет. См. также статью [[Объект базы данных]].&lt;br /&gt;
&lt;br /&gt;
== Синтаксис ==&lt;br /&gt;
&amp;lt;code&amp;gt;&lt;br /&gt;
'''MassLoadObjects'''(''&amp;lt;Объект для загрузки&amp;gt;''{{Optional|,&amp;lt;Аргумент 1&amp;gt;,&amp;lt;Аргумент 2&amp;gt;,&amp;lt;Также загружать периодические реквизиты (INT)&amp;gt;{{Default|{{Eq}}0}},&amp;lt;Производить загрузку заголовков (INT)&amp;gt;{{Default|{{Eq}}0}},&amp;lt;Доп. реквизиты при загрузке заголовков (STRING)&amp;gt;{{Default|{{Eq}}&amp;quot;&amp;quot;}}}}):''&amp;lt;Количество объектов, которые были загружены (INT)&amp;gt;''&lt;br /&gt;
&amp;lt;/code&amp;gt;&lt;br /&gt;
==== Аргументы ====&lt;br /&gt;
* &amp;lt;code&amp;gt;''&amp;lt;Объект для загрузки&amp;gt;''&amp;lt;/code&amp;gt; - Объект, содержащий объекты для загрузки. Данный объект может быть:&lt;br /&gt;
** '''список значений''' -- будут загружены объекты из списка. Последующие два аргумента могут задавать начальный индекс списка (первый объект для загрузки) и конечный индекс списка (последний объект для загрузки) соответственно.&lt;br /&gt;
** '''таблица значений''' -- будут загружены объекты из таблицы значений. Последующие два аргумента могут иметь следующее значение:&lt;br /&gt;
*** В случае, если аргументы представляют собой целые числа, они задают индекс начальной строки загрузки и индекс конечной строки загрузки соответственно. В этом режиме объекты будут собираться из всех столбцов таблицы. Для исключения определенных столбцов таблицы из загрузки также смотрите статью [[Tab.Column.ForbidMassLoad|ForbidMassLoad]].&lt;br /&gt;
*** В случае, если аргументы представляют собой строки, первый задает наименования столбцов для загрузки через запятую (пустое значение -- все столбцы), второй задает наименования столбцов для пропуска (т.е., список столбцов, которые не нужно загружать) через запятую. В этом режиме объекты будут собираться для всех строк таблицы, но только для определенных ее столбцов. Для исключения определенных столбцов таблицы из загрузки также смотрите статью [[Tab.Column.ForbidMassLoad|ForbidMassLoad]].&lt;br /&gt;
** '''дерево значений''' или '''ветка дерева значений''' -- будут загружены объекты из дерева/ветки значений. Дополнительные аргументы не требуются.&lt;br /&gt;
** '''объект базы данных''' -- если объект загружен, будут загружены любые объекты, являющиеся его реквизитами. Также будут загружены любые объекты любой из его загруженных строчных частей. Дополнительные аргументы не требуются.&lt;br /&gt;
* &amp;lt;code&amp;gt;''&amp;lt;Аргумент 1&amp;gt;'',''&amp;lt;Аргумент 2&amp;gt;''&amp;lt;/code&amp;gt; - {{optional}} Значения этих аргументов зависят от типа объекта загрузки (первого аргумента).&lt;br /&gt;
* &amp;lt;code&amp;gt;''&amp;lt;Также загружать периодические реквизиты (INT)&amp;gt;''{{Default|{{eq}}0}}&amp;lt;/code&amp;gt; - {{optional}} Режим позволяет при загрузке объектов также загружать их периодические реквизиты (см. статью [[Объект базы данных]]). Периодические реквизиты будут загружены на дату периодических реквизитов объектов (см. [[DB.UseDate|UseDate]]).&lt;br /&gt;
* &amp;lt;code&amp;gt;''&amp;lt;Производить загрузку заголовков (INT)&amp;gt;''{{Default|{{eq}}0}}&amp;lt;/code&amp;gt; - {{optional}} Режим загрузки только заголовков (см. статью [[Объект базы данных]]). Аргумент может принимать следующие значения:&lt;br /&gt;
** '''0''' -- производить полную загрузку объектов&lt;br /&gt;
** '''1''' -- производить загрузку объектов в режиме ''только заголовки'' или ''частичная загрузка'' (в зависимости от наличия следующего аргумента), объекты, которые не могут быть загружены частично, будут пропущены. К примеру, если при настройке проекта для объекта не задан реквизит сортировки, данный объект не может быть загружен в режиме только заголовков.&lt;br /&gt;
** '''2''' -- производить загрузку объектов в режиме ''только заголовки'' или ''частичная загрузка'' (в зависимости от наличия следующего аргумента), объекты, которые не могут быть загружены частично, будут загружены полностью. К примеру, если при настройке проекта для объекта не задан реквизит сортировки, данный объект не может быть загружен в режиме только заголовков.&lt;br /&gt;
* &amp;lt;code&amp;gt;''&amp;lt;Доп. реквизиты при загрузке заголовков (STRING)&amp;gt;''&amp;lt;/code&amp;gt; - {{optional}} Список наименований реквизитов через запятую, которые будут загружены дополнительно в режиме загрузки только заголовков. В случае, когда этот аргумент задан, объекты будут загружены в режиме &amp;quot;частичная загрузка&amp;quot;. Если наименование реквизита в загружаемом объекте отсутствует, оно будет пропущено. Таким образом можно загружать разные объекты одним вызовом функции, указав всю совокупность реквизитов для частичной загрузки.&lt;br /&gt;
&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;
//Ниже дан кусок кода для события OnBeforeLoadElements, производится заполнение таблицы Tab, в которую загружаются&lt;br /&gt;
//  подчиненные элементы справочника НаценкиНаГруппы, чтобы ускорить загрузку и уменьшить потребление памяти,&lt;br /&gt;
//  при этом, для таблицы необходимы не сами элементы, а объекты, помещенные в реквизит ГруппаНоменклатуры, т.е., элементы&lt;br /&gt;
//  представляют собой строчную часть с одним реквизитом ГруппаНоменклатуры.&lt;br /&gt;
//  Нам необходимо собрать все объекты из реквизитов ГруппаНоменклатуры и осуществить их загрузку в режиме частичной загрузки.&lt;br /&gt;
//&lt;br /&gt;
//  В таблице выводятся наименование загруженных объектов, реквизит &amp;quot;Code&amp;quot; загруженных объектов и иконка, соответствующая папке,&lt;br /&gt;
//  если элемент был папкой справочника Номенклатура. Поэтому для частичной загрузки достаточно реквизита &amp;quot;Code&amp;quot;, остальные&lt;br /&gt;
//  перечисленные свойства всегда загружаются в этом режиме.&lt;br /&gt;
//&lt;br /&gt;
&lt;br /&gt;
Tab:=Form.Tab.Value;&lt;br /&gt;
aEl:=Ref.НаценкиНаГруппы;&lt;br /&gt;
//Загрузка нужных элементов (не удаленных) справочника НаценкиНаГруппы в список aList&lt;br /&gt;
//Полная загрузка будет осуществлена быстро, так как элементы простые и содержат минимум реквизитов&lt;br /&gt;
aList:=aEl.Load(0,&amp;quot;@Parent,@Status&amp;quot;,Form.Tab.ParentElement,0);&lt;br /&gt;
&lt;br /&gt;
//Заполняем вспомогательный список bList, для частичной загрузки всех реквизитов ГруппаНоменклатуры &lt;br /&gt;
bList:=List.Create();&lt;br /&gt;
//Цикл по всем загруженным элементам НаценкиНаГруппы&lt;br /&gt;
For i:=1 To aList.Size() Do&lt;br /&gt;
  Эл:=aList.Get(i);&lt;br /&gt;
  //Создание списка bList, состоящего из реквизитов ГруппаНоменклатуры загруженных элементов&lt;br /&gt;
  //  каждый из этих реквизитов пока не загружен, реквизиты содержат справочник Номенклатуры, с &amp;quot;тяжелыми&amp;quot; для загрузки элементами.&lt;br /&gt;
  bList.Add(Эл.ГруппаНоменклатуры);&lt;br /&gt;
EndDo;&lt;br /&gt;
//Загрузка всех накопленных элементов в режиме частичной загрузки, будут загружены наименования, реквизиты сортировки, свойства типа &amp;quot;удален&amp;quot;, &amp;quot;папка&amp;quot; и пр., &lt;br /&gt;
//  и реквизит &amp;quot;Code&amp;quot;, требуемый для отображения&lt;br /&gt;
MassLoadObjects(bList,,,0,1,&amp;quot;Code&amp;quot;);&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Tab.Lock();&lt;br /&gt;
Try&lt;br /&gt;
  //Заполняем визуальную таблицу Tab из оригинального списка aList&lt;br /&gt;
  //Важно понимать, что все реквизиты ГруппаНоменклатуры каждого из элементов списка загружены &lt;br /&gt;
  //  в режиме частичной загрузки ранее, для этого мы собирали их в список и вызывали MassLoadObjects&lt;br /&gt;
  aList.CopyTo(Tab,1,aList.Size(),&amp;quot;@ELEMENT&amp;quot;);&lt;br /&gt;
  Tab.Select();&lt;br /&gt;
  While Tab.Next() Do&lt;br /&gt;
    Эл:=Tab.Get(Tab.CurLine,&amp;quot;@ELEMENT&amp;quot;);&lt;br /&gt;
    //Эл.ГруппаНоменклатуры -- загружен в режиме частичной загрузки,&lt;br /&gt;
    //  чтение реквизитов и свойств, типа isFolder, Status не приведет к полной загрузке&lt;br /&gt;
    Tab.isFolder:=Эл.ГруппаНоменклатуры.isFolder();&lt;br /&gt;
    //Вывод на экран представления элемента также не приведет к к полной загрузке элемента&lt;br /&gt;
    Tab.ГруппаНоменклатуры:=Эл.ГруппаНоменклатуры;&lt;br /&gt;
    //Частичная загрузка также включала реквизит &amp;quot;Code&amp;quot;, поэтому его безопасно добавить в выводимую таблицу&lt;br /&gt;
    Tab.Code:=Эл.ГруппаНоменклатуры.Code;&lt;br /&gt;
    //При частичной загрузке загруженных свойств достаточно, чтобы показать стандартную иконку (папка, элемент, удаленная папка, удаленный элемент)&lt;br /&gt;
    //Обратите внимание: стандартная иконка выводится для реквизита ГруппаНоменклатуры, а не для самого элемента Эл&lt;br /&gt;
    Tab.Icon(i,&amp;quot;Icon&amp;quot;,GetStandardIcon(Эл.ГруппаНоменклатуры));&lt;br /&gt;
    //Остальные свойства берутся из элементов справочника НаценкиНаГруппы, которые подверглись полной загрузке&lt;br /&gt;
    Tab.Сумма:=Эл.Сумма;&lt;br /&gt;
    Tab.Процент:=Эл.Процент;&lt;br /&gt;
  EndDo;&lt;br /&gt;
  //Сортируем таблицу с учетом текущих визуальных настроек сортировки&lt;br /&gt;
  Стр:=&amp;quot;isFolder-&amp;quot;+?(Form.Tab.SortString=&amp;quot;&amp;quot;,&amp;quot;&amp;quot;,&amp;quot;,&amp;quot;+Form.Tab.SortString);&lt;br /&gt;
  Tab.Sort(Стр);&lt;br /&gt;
Finally&lt;br /&gt;
  Tab.Unlock();&lt;br /&gt;
EndTry;&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>
		
	</entry>
</feed>