Ускоряем типовую обработку "Групповое изменение реквизитов" правкой пары строчек кода

19.03.19

Разработка - Универсальные функции

Данные правки помогут ускорить выполнение обработки для большого числа изменяемых объектов (выполнения задания в фоне) без использования транзакций.

Заметил такую не очень приятную особенность выполнения типовой обработки - выполнение задания в фоне идет только когда указываешь в форме "Дополнительные параметры" ИзменятьВТранзакции = Истина, иначе выполнение обработки идет в текущем сеансе

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

Поэтому с помощью всего пары правок можно заставить обработку выполняться в фоне, когда число выбранных объектов, например, больше 100

Для этого в модуле формы обработки в процедуре ИзменитьОбъекты() нужно заменить строчку

Если Объект.ИзменятьВТранзакции Тогда

На

Если Объект.ИзменятьВТранзакции Или КоличествоОбъектовДляОбработки >= 100 Тогда

И в функции ИзменитьНаСервере(Знач ОстанавливатьИзменениеПриОшибке) заменить

Если Не Объект.ИзменятьВТранзакции Или Не ПодсистемаСуществует("СтандартныеПодсистемы.БазоваяФункциональность") Тогда

На

Если (Не Объект.ИзменятьВТранзакции И КоличествоВыбранныхОбъектов() < 100) Или Не ПодсистемаСуществует("СтандартныеПодсистемы.БазоваяФункциональность") Тогда

Теперь если выбранных объектов больше и равно 100, то задание изменения будет выполняться всегда в фоне

Вступайте в нашу телеграмм-группу Инфостарт

См. также

Загрузка и выгрузка в Excel Универсальные функции Программист 1С:Предприятие 8 Россия Бесплатно (free)

Описанный ниже подход позволяет в три шага заполнять формулы в Excel файлы, вне зависимости от ОС сервера (MS Windows Server или Linux). Подход подразумевает отказ от работы с COM-объектом в пользу работы через "объектную модель документа" (DOM).

30.10.2025    3396    Abysswalker    8    

45

Универсальные функции Работа с интерфейсом Программист 1С:Предприятие 8 Бесплатно (free)

Порой необходимо временно отключить расширение 1С, не удаляя его, чтобы не потерять данные. Но в этом случае при каждом запуске всем будет лезть уведомление о неактивном расширении, хотя очевидно, это техническая информация, которой не стоит лишний раз пугать пользователей.

14.05.2025    6312    DeerCven    15    

57

Универсальные функции Программист 1С:Предприятие 8 1C:Бухгалтерия Бесплатно (free)

Благодаря этим пяти строчкам можно больше не заморачиваться с загрузкой из внешних файлов. Пользуюсь везде, всегда и постоянно.

21.05.2024    48636    dimanich70    83    

169

Универсальные функции Программист 1С:Предприятие 8 1C:Бухгалтерия Абонемент ($m)

Задача: вставить картинку из буфера обмена на форму средствами платформы 1С.

1 стартмани

18.03.2024    7285    6    John_d    13    

59

Универсальные функции Программист Стажер 1С:Предприятие 8 1C:Бухгалтерия Бесплатно (free)

Пришлось помучиться с GUID-ами немного, решил поделиться опытом, мало ли кому пригодится.

12.02.2024    60799    atdonya    31    

69

Универсальные функции Программист 1С:Предприятие 8 Бесплатно (free)

На заключительных этапах, когда идет отладка или доработка интерфейса, необходимо много раз переоткрыть внешний объект. Вот один из способов автоматизации этого.

30.11.2023    9077    ke.92@mail.ru    17    

68
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. user-z99999 77 19.03.19 12:53 Сейчас в теме
А если заменить?
Если Объект.ИзменятьВТранзакции Или КоличествоОбъектовДляОбработки >= 100 Тогда

на
Если КоличествоОбъектовДляОбработки >= 100 Или Объект.ИзменятьВТранзакции  Тогда

Какое из условий чаще возникает, то и должно быть на первом месте.
2. w.r. 655 19.03.19 13:31 Сейчас в теме
(1) это уже вам самим решать, какое условие у вас будет чаще возникать. Я оставил по умолчанию условие типовое на первом месте
3. RustIG 1934 29.04.19 22:18 Сейчас в теме
Для отправки сообщения требуется регистрация/авторизация