Содержание:
2. Режимы управления блокировками для объектов конфигурации
3. Управляемая блокировка в коде
4. Исключительная управляемая блокировка
1. О блокировке в 1С 8.3
Блокировка – обязательный функционал многопользовательской системы.
Любой объект системы во время чтения и изменения должен быть заблокирован от других процессов. Блокироваться объект может как СУБД, так и самим приложением 1С. Именно из-за области воздействия блокировок они бывают объектными и транзакционными. Объектное блокирование – это вид, реализованный на уровне платформы 1С, не затрагивающий СУБД. Транзакционное блокирование – это механизм, который работает на уровне СУБД. Транзакционные подразделяются на автоматические и управляемые блокировки.
Режим автоматических блокировок предоставляется и исполняется СУБД.
Режим управляемых блокировок данных выполняется не моделями данных СУБД, а в терминах предметной области 1С. Благодаря этому блокировки накладываются «точнее» и параллельность работы пользователей повышается. При выполнении каждой операции с базой данных менеджер блокировок 1С 8.3 проверяет возможность блокировки ресурсов.
2. Режимы управления блокировками для объектов конфигурации
В Конфигураторе в свойствах можно установить вариант блокировки на все объекты конфигурации.
Свойство "Режим управления блокировкой данных":
Рис. 1 Режим управления блокировкой данных
Для конкретного объекта конфигурации тоже можно установить режим блокировки – свойство "Режим управления блокировкой":
Рис. 2 Свойство "Режим управления блокировкой"
Этот режим предназначен для частичного перевода конфигурации в режим управляемых блокировок. Он позволяет отдельным объектам метаданных работать с управляемыми блокировками в 1С, в то время как остальные объекты работают в режиме автоматических блокировок. Это и есть автоматический и управляемый режимы.
3. Управляемая блокировка в коде
Блокировки в коде создаются и устанавливаются с помощью методов и свойств.
Создать объект блокировка данных –
БлокировкаДанных = Новый БлокировкаДанных;
Добавить новый элемент блокировки
ЭлементБлокировки = БлокировкаДанных.Добавить("ключ")
Установить режим блокировки
ЭлементБлокировки.Режим = РежимБлокировкиДанных.Разделяемый/Исключительный
Установить значение блокируемых данных
ЭлементБлокировки.УстановитьЗначение("ключ", ЗначениеКлюча);
ЭлементБлокировки.УстановитьЗначение("Период", ЗаданныйДиапазонДат);
ЭлементБлокировки.ИспользоватьИзИсточникаДанных("ключ", "ключ")
Блокировки в коде устанавливаются при изменении объектов, реквизитов, данных, и т.д.
1.Явное задание имени объекта блокировки и его значения
БлокировкаДанных = Новый БлокировкаДанных;
ЭлементБлокировки = БлокировкаДанных.Добавить("РегистрНакопления.ОстаткиТоваровНаСкладах");
ЭлементБлокировки.Режим = РежимБлокировкиДанных.Исключительный;
ЭлементБлокировки.УстановитьЗначение("Склад", Склад);
В данном случае мы блокируем в данных регистра "ОстаткиТоваровНаСкладах" все записи, у которых
значение измерения "Склад" равно значению, содержащемуся в переменной "Склад"
2.Задание блокировки с указанием источника данных, содержащего необходимые значения
БлокировкаДанных = Новый БлокировкаДанных;
ЭлементБлокировки = БлокировкаДанных.Добавить("РегистрНакопления.ПродажиТоваров");
ЭлементБлокировки.Режим = РежимБлокировкиДанных. Разделяемый;
ЭлементБлокировки.УстановитьЗначение("Покупатель", Покупатель);
Диапазон = Новый Диапазон(НачалоМесяца(Дата), Дата);
ЭлементБлокировки.УстановитьЗначение("Период", Диапазон);
Ну, а в этом примере, мы блокируем в данных регистра "ПродажиТоваров" все записи, у которых
значение измерения "Покупатель" равно значению, содержащемуся в переменной "Покупатель",
а значение поля "Период" содержится в указанном диапазоне (НачалоМесяца(Дата), Дата).
3.Установка условия блокировки записей с помощью источника данных
БлокировкаДанных = Новый БлокировкаДанных;
ЭлементБлокировки = БлокировкаДанных.Добавить("РегистрНакопления.ОстаткиТоваровНаСкладах");
ЭлементБлокировки.Режим = РежимБлокировкиДанных.Исключительный;
ЭлементБлокировки.УстановитьЗначение("Склад", Склад);
ЭлементБлокировки.ИсточникДанных = СписокНоменклатуры;
ЭлементБлокировки.ИспользоватьИзИсточникаДанных("Номенклатура", "Номенклатура");
Данные для установки ограничений на поля этого элемента блокировки – это таблица значений "СписокНоменклатуры". Блокируем в данных регистра "ОстаткиТоваровНаСкладах" все записи, у которых значение измерения "Склад" равно значению переменной "Склад", а значение измерения "Номенклатура" равно какому-либо значению из колонки "Номенклатура", указанного источника данных. В качестве источника данных можно указывать результат запроса, и для последнего примера можно было бы создать запрос, который бы отсекал номенклатуру, содержащую "услугу", тем самым нивелируя избыточность блокировки.
4. Исключительная управляемая блокировка
При любой попытке модификации данных информационной базы система автоматически будет устанавливать исключительные блокировки для этих данных.
Использование "разделяемой" блокировкой может привести к конфликту блокировок. Например, две транзакции начали считывать остатки из регистра "Списки номенклатуры", остатки имеют одинаковые элементы. При этом система в первой и второй транзакции устанавливает разделяемую блокировку на считываемые ресурсы. Эти две блокировки на один и тот же ресурс совместимы друг с другом, потому что они разделяемые. Далее первая транзакция прочитала данные, изменила и теперь хочет их записать, но сделать это не может, т.к. для этого система должна установить исключительную блокировку на записываемые данные, чему мешает разделяемая блокировка второй транзакции. Первая транзакция становится в очередь, ожидая снятия разделяемой блокировки, установленной второй транзакцией. Вторая транзакция также закончила чтение данных и хочет записать новые данные. Все повторяется – она не может это сделать, т.к. для этого система должна установить исключительную блокировку на записываемые данные, но этому мешает разделяемая блокировка, установленная на часть этих данных первой транзакцией. Вторая транзакция становится в очередь, ожидая снятия разделяемой блокировки, установленной первой транзакцией – круг замкнулся, и мы получаем конфликт блокировок.
При установлении исключительной блокировки таких конфликтов возникать не может.
Специалист компании «Кодерлайн»
Ольга Волкова