Управляемые блокировки
-

Управляемые блокировки

1
617
28.02.2022 Ольга Волкова

Содержание:

1.      О блокировке в 1С 8.3

2.      Режимы управления блокировками для объектов конфигурации

3.      Управляемая блокировка в коде

4.      Исключительная управляемая блокировка


1.       О блокировке в 1С 8.3

 

Блокировка – обязательный функционал многопользовательской системы.

 

Любой объект системы во время чтения и изменения должен быть заблокирован от других процессов. Блокироваться объект может как СУБД, так и самим приложением 1С. Именно из-за области воздействия блокировок они бывают объектными и транзакционными. Объектное блокирование – это вид, реализованный на уровне платформы 1С, не затрагивающий СУБД. Транзакционное блокирование – это механизм, который работает на уровне СУБД. Транзакционные подразделяются на автоматические и управляемые блокировки.

 

Режим автоматических блокировок предоставляется и исполняется СУБД.

 

Режим управляемых блокировок данных выполняется не моделями данных СУБД, а в терминах предметной области 1С. Благодаря этому блокировки накладываются «точнее» и параллельность работы пользователей повышается. При выполнении каждой операции с базой данных менеджер блокировок 1С 8.3 проверяет возможность блокировки ресурсов.  

 

2.       Режимы управления блокировками для объектов конфигурации

 

В Конфигураторе в свойствах можно установить вариант блокировки на все объекты конфигурации.

 

Свойство "Режим управления блокировкой данных":



Рис. 1 Режим управления блокировкой данных

 

Для конкретного объекта конфигурации тоже можно установить режим блокировки – свойство "Режим управления блокировкой":



Рис. 2 Свойство "Режим управления блокировкой"

 

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

 

3.       Управляемая блокировка в коде


Блокировки в коде создаются и устанавливаются с помощью методов и свойств.

 

Создать объект блокировка данных –

            БлокировкаДанных = Новый БлокировкаДанных;

Добавить новый элемент блокировки

            ЭлементБлокировки = БлокировкаДанных.Добавить("ключ")

Установить режим блокировки

            ЭлементБлокировки.Режим = РежимБлокировкиДанных.Разделяемый/Исключительный

Установить значение блокируемых данных

            ЭлементБлокировки.УстановитьЗначение("ключ", ЗначениеКлюча);

            ЭлементБлокировки.УстановитьЗначение("Период", ЗаданныйДиапазонДат);

            ЭлементБлокировки.ИспользоватьИзИсточникаДанных("ключ", "ключ")

 

Блокировки в коде устанавливаются при изменении объектов, реквизитов, данных, и т.д.

 

1.Явное задание имени объекта блокировки и его значения

 

БлокировкаДанных = Новый БлокировкаДанных;

ЭлементБлокировки = БлокировкаДанных.Добавить("РегистрНакопления.ОстаткиТоваровНаСкладах");

ЭлементБлокировки.Режим = РежимБлокировкиДанных.Исключительный;

ЭлементБлокировки.УстановитьЗначение("Склад", Склад);

 

В данном случае мы блокируем в данных регистра "ОстаткиТоваровНаСкладах" все записи, у которых

значение измерения "Склад" равно значению, содержащемуся в переменной "Склад"

 

2.Задание блокировки с указанием источника данных, содержащего необходимые значения

 

БлокировкаДанных = Новый БлокировкаДанных;

ЭлементБлокировки = БлокировкаДанных.Добавить("РегистрНакопления.ПродажиТоваров");

ЭлементБлокировки.Режим = РежимБлокировкиДанных. Разделяемый;

ЭлементБлокировки.УстановитьЗначение("Покупатель", Покупатель);

Диапазон = Новый Диапазон(НачалоМесяца(Дата), Дата);

ЭлементБлокировки.УстановитьЗначение("Период", Диапазон);

 

Ну, а в этом примере, мы блокируем в данных регистра "ПродажиТоваров" все записи, у которых

значение измерения "Покупатель" равно значению, содержащемуся в переменной "Покупатель",

а значение поля "Период" содержится в указанном диапазоне (НачалоМесяца(Дата), Дата).

 

3.Установка условия блокировки записей с помощью источника данных

 

БлокировкаДанных = Новый БлокировкаДанных;

ЭлементБлокировки = БлокировкаДанных.Добавить("РегистрНакопления.ОстаткиТоваровНаСкладах");

ЭлементБлокировки.Режим = РежимБлокировкиДанных.Исключительный;

ЭлементБлокировки.УстановитьЗначение("Склад", Склад);

ЭлементБлокировки.ИсточникДанных = СписокНоменклатуры;

ЭлементБлокировки.ИспользоватьИзИсточникаДанных("Номенклатура", "Номенклатура");

 

Данные для установки ограничений на поля этого элемента блокировки – это таблица значений "СписокНоменклатуры". Блокируем в данных регистра "ОстаткиТоваровНаСкладах" все записи, у которых значение измерения "Склад" равно значению переменной "Склад", а значение измерения "Номенклатура" равно какому-либо значению из колонки "Номенклатура", указанного источника данных. В качестве источника данных можно указывать результат запроса, и для последнего примера можно было бы создать запрос, который бы отсекал номенклатуру, содержащую "услугу", тем самым нивелируя избыточность блокировки.  

 

4.       Исключительная управляемая блокировка

 

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

 

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

 

При установлении исключительной блокировки таких конфликтов возникать не может.

 

Специалист компании «Кодерлайн»

Ольга Волкова

Задать вопрос автору статьи
Тема вопроса*
Ваше имя*
E-mail или телефон*
Ваш вопрос*
 

0
Alexey
Вы решительно зря игнорируете тег <code> для кусков кода
Имя Цитировать 0
Добавить комментарий
Текст сообщения*
Защита от автоматических сообщений
 
Теги
#1С: CRM #1С: ERP #1С: ERP Управление строительной организацией #1С: ERP. Управление буровой компанией #1С: WMS Управление складом #1С: Аренда и управление недвижимостью #1С: БУХ #1С: Договорчики #1С: Документооборот #1С: ЗУП #1С: Интеграция #1С: КА #1С: Колледж #1С: Конвертация данных #1С: Модули #1С: Платформа #1С: Розница #1С: Сценарное тестирование #1С: ТОИР #1С: УАТ #1С: УКФ #1С: Университет #1С: УНФ #1С: УПП #1С: Управление строительной организацией #1С: УТ #1С: УХ #1С:ERP #1С:БГУ #1С:БП #1С.6-НДФЛ #ADO #APACHE #API #canonical #com-объекты #Excel #Excel в 1С #GoogleDrive #HTTP #ITIL #Koderline: Управление медиа-холдингом #Koderline: Управление проектами строительства скважин #LINUX #MS SQL Server #WEB #WEB-сервисы 1С #Word #XML #Администрирование 1С #акты в 1С #Безопасность сервера #Бесшовная интеграция #БИТ.Финанc #Битрикс24 #Блокировки в 1С #БСП #БУ #Бурение скважин #Бюджетирование #Внедрение #Внедрение ERP #Закрытие месяца #Запросы 1С #Интеграция 1С #КАК ОТРАЖАЮТСЯ ТОВАРЫ В ПУТИ 1С #Как сделать в 1С #Конвертация данных #Корпоративное сопровождение #Лизинг #Лицензии 1С #Механизм Анализа Данных в 1С #Моделирование #Модуль Диадок #МСФО #Налоги #Обмен между базами #Обновления #Оптимизация #Отпуск #Отчетность #Отчеты в 1С #Оценка задач #Перенос данных #Планирование #Полезные обработки #Правила обмена #предопределенные элементы справочников #Проводки 1С #Программирование в 1С #Программные права #Продажи #Производство #Работа с объектами в 1С #Расширение конфигурации #РСБУ #С # #СКД #Соединение COM в 1С платформе #Сравнение конфигураций #Тестирование 1С #Техническое задание #Торговое оборудование #Транспортная логистика #Управление проектами #Финансовый учет #Хранилище настроек #Ценообразование #Экзамен 1С #Яндекс.Касса 1С под Linux 1С:УНФ Email или телефон Работа с объектами в 1С Функциональные опции в 1С
Услуги программиста 1С
Получите специалиста  
для решения всех задач
в области 1С
Программы 1С
Цены и подробное описание программ 1С:Предприятие 8.