|
Заблокировать процедуру до принудительной разблокировки
|
|||
---|---|---|---|
#18+
Oracle 12. Есть процедура расчета, которую можно запускать только со специальным разрешением. Сначала попробовала через пакет DBMS_LOOK: Есть процедура выдачи разрешения (снимает блокировку). Процедура расчета при запуске создает ту же самую блокировку, если не может создать - падает с сообщением, что разрешение на запуск еще не выдано. В этом решении не могу придумать как снять блокировку из другой процедуры. Основная проблема - как и где хранить ID блокировки, чтобы воспользоваться позже? Если писать ID в пользовательскую таблицу, то тогда не нужен пакет DBMS_LOOK, можно просто проверять значение параметра в таблице. Есть еще идеи? ... |
|||
:
Нравится:
Не нравится:
|
|||
02.07.2020, 16:23 |
|
Заблокировать процедуру до принудительной разблокировки
|
|||
---|---|---|---|
#18+
l_kator, можна попробовать флажок выставлять через контекст (глобальный) имхо, самое простое и понятное - строка в таблице "разрешений" ps не все понял о DBMS_LOOK ..... stax ... |
|||
:
Нравится:
Не нравится:
|
|||
02.07.2020, 16:33 |
|
Заблокировать процедуру до принудительной разблокировки
|
|||
---|---|---|---|
#18+
Stax, видимо так и будет реализовано, просто давно не была в Оракле, может есть уже что-нибудь изящное, а я не в курсе :) Elic, как упорядоченный бардак поможет в реализации описанной блокировки? ... |
|||
:
Нравится:
Не нравится:
|
|||
02.07.2020, 16:43 |
|
Заблокировать процедуру до принудительной разблокировки
|
|||
---|---|---|---|
#18+
l_kator Stax, может есть уже что-нибудь изящное мож и есть в своей табличке можно не просто флажок 0/1 выставлять, а и другие условия (напр время запуска) .... stax ... |
|||
:
Нравится:
Не нравится:
|
|||
02.07.2020, 17:17 |
|
Заблокировать процедуру до принудительной разблокировки
|
|||
---|---|---|---|
#18+
Dimitry Sibiryakov l_katorкак упорядоченный бардак поможет в реализации описанной блокировки? Устранив её необходимость. А как порядок в моей голове может устранить запрос заказчика на эту функциональность? ... |
|||
:
Нравится:
Не нравится:
|
|||
02.07.2020, 18:58 |
|
Заблокировать процедуру до принудительной разблокировки
|
|||
---|---|---|---|
#18+
Stax l_kator Stax, может есть уже что-нибудь изящное мож и есть в своей табличке можно не просто флажок 0/1 выставлять, а и другие условия (напр время запуска) .... stax Спасибо! Это отличная идея! И имя пользователя, которому выдано разрешение, тоже добавлю! ... |
|||
:
Нравится:
Не нравится:
|
|||
02.07.2020, 18:59 |
|
|
start [/forum/topic.php?fid=52&fpage=42&tid=1881101]: |
0ms |
get settings: |
6ms |
get forum list: |
10ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
40ms |
get topic data: |
10ms |
get forum data: |
2ms |
get page messages: |
37ms |
get tp. blocked users: |
2ms |
others: | 309ms |
total: | 422ms |
0 / 0 |