28.02.2022 Ольга Волкова 28125
Управляемые блокировки

Содержание:

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.       Исключительная управляемая блокировка

 

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

 

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

 

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

 

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

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

Наши проекты

Автоматизация производственного планирования нефтесервисной компании на базе 1С:ЕРП 2.0
ЗАО «Инвестгеосервис»

Отрасль:
Нефтесервис

Внедренное типовое решение:
1С:ERP Управление предприятием 2.0

- Блок планирования проектов (процессы объемно-календарного планирования пр...

ХИТЕК-ГРУП
ХИТЕК-ГРУП

Отрасль:
Продажа парикмахерского инструмента и аксессуаров

Внедренное типовое решение:
1С:ERP Управление предприятием 2.0

Документооборот (ECM)
• Делопроизводство
Управление бизнес-процессами и И...

ООО «Еврорадиаторы»
ООО «Еврорадиаторы»

Отрасль:
1С:ERP 2.4

Внедренное типовое решение:

Специалисты «Кодерлайн» помогли перенести базу из текущей системы «1С:ERP 2.2» ...

ОАО «Фаберлик»
ОАО «Фаберлик»

Отрасль:

Внедренное типовое решение:
1С:ERP. Управление производственным предприятием 2

- Регламентированный учет;
- Кадровый учет;...

Внедрение ПП "1С:Управление небольшой фирмой 8 ПРОФ" в ООО «Шокостайл»
ООО «Шокостайл»

Отрасль:
Производство

Внедренное типовое решение:
1С:Управление небольшой фирмой 8 ПРОФ

Управление продажами, логистикой и транспортом (SFM, WMS, TMS):
- Планирование п...

ООО «Лаборатория успеха»
ООО «Лаборатория успеха»

Отрасль:
Общественное и плановое питание, гостиничный бизнес, туризм

Внедренное типовое решение:
1С:Зарплата и управление персоналом 8. КОРП

Кадровый учет;
Расчет зарплаты;...

АО "Нижегородский водоканал"
АО "Нижегородский водоканал"

Отрасль:
Профессиональные услуги

Внедренное типовое решение:
1С:Зарплата и управление персоналом 8. КОРП

-Кадровый учет
-Расчет зарплаты
-Регламентированная отчетность
-Подбор ...

МИР ХОББИ
МИР ХОББИ

Отрасль:
Торговля. Интернет магазин

Внедренное типовое решение:
1С:ERP Управление предприятием 2.0

Оформление заказов поставщикам
Взаиморасчеты с покупателями
Оформление...

ООО «Солви Пак»
ООО «Солви Пак»

Отрасль:
Торговля. Производство печати на рулонных материалах

Внедренное типовое решение:
1С:CRM+1С:Комплексная автоматизация

Управление отношениями с клиентами (CRM) ...

Автоматизация интеграции с информсистемами клиентов на базе «1С:Предприятие 8. WMS Логистика. Управление складом»
ОАО «Фрейт Линк»

Отрасль:
Логистика и грузоперевозки

Внедренное типовое решение:
«1С:Предприятие 8. WMS Логистика. Управление складом»

– Управление складскими запасами;
– Оформление заказов покупателей;
– ...

ООО ХДМ Рус
ООО ХДМ Рус

Отрасль:
Торговля

Внедренное типовое решение:
1С:Управление торговлей

Управление цепочками поставок Оптовая торговля ...

Автоматизация торгового учета на базе "1С:Управление торговлей"
ООО «ТЕЛЕВЕС РУСС»

Отрасль:
Торговля

Внедренное типовое решение:
1С:Управление торговлей

- Управление складскими запасами;
- Оформление заказов покупателей;
- Пла...

Наши соц. сети

Telegram-канал «Koderline 1С» Группа в Вконтакте «Кодерлайн КОРП» Rutube

Остались вопросы - обратитесь к нам!

Впишите свои Имя и Телефон, чтобы мы ответили на все интересующие Вас вопросы.
ФИО*
E-mail*
Телефон*
Сообщение