|
Как гарантировано переименовать таблицу?
|
|||
---|---|---|---|
#18+
Всем привет, во время работы расчета выполняется вот такой шаг: Код: sql 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. 16. 17. 18. 19. 20. 21.
Но иногда возникает ситуация, когда после применения Код: sql 1.
К базе подключается другая сессия и моя обработка прерывается. Подскажите, после выполнения ALTER DATABASE SET SINGLE_USER, могу ли я гарантировано занять коннект к базе? ... |
|||
:
Нравится:
Не нравится:
|
|||
01.02.2022, 16:50 |
|
Как гарантировано переименовать таблицу?
|
|||
---|---|---|---|
#18+
teCa, Если этот код выполняется в одном пакете, то как другой сеанс подключится к базе? Значит пакет падает с ошибкой и вы теряете подключение. ... |
|||
:
Нравится:
Не нравится:
|
|||
01.02.2022, 17:37 |
|
Как гарантировано переименовать таблицу?
|
|||
---|---|---|---|
#18+
Владислав Колосов teCa, Если этот код выполняется в одном пакете, то как другой сеанс подключится к базе? Значит пакет падает с ошибкой и вы теряете подключение. Вопрос неверный. Верный вопрос: нафига в данном скрипте SET SINGLE_USER WITH ROLLBACK IMMEDIATE? Пригорает, чтоли? ЗЫ. За такую профнепригодность гнать надо. ... |
|||
:
Нравится:
Не нравится:
|
|||
01.02.2022, 17:53 |
|
Как гарантировано переименовать таблицу?
|
|||
---|---|---|---|
#18+
teCa, Оберните все ваше хозяйство в Код: sql 1. 2. 3. 4. 5. 6. 7.
без SET SINGLE_USER ... |
|||
:
Нравится:
Не нравится:
|
|||
01.02.2022, 18:03 |
|
Как гарантировано переименовать таблицу?
|
|||
---|---|---|---|
#18+
нафига в данном скрипте Ну как... понаехали тут, переименовать не дают... ... |
|||
:
Нравится:
Не нравится:
|
|||
01.02.2022, 20:50 |
|
Как гарантировано переименовать таблицу?
|
|||
---|---|---|---|
#18+
aleks222, А что не так, можете объяснить? В BOL именно такой пример: Код: sql 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12.
https://docs.microsoft.com/ru-ru/sql/relational-databases/databases/set-a-database-to-single-user-mode?view=sql-server-ver15 ... |
|||
:
Нравится:
Не нравится:
|
|||
02.02.2022, 11:21 |
|
Как гарантировано переименовать таблицу?
|
|||
---|---|---|---|
#18+
teCa aleks222, А что не так, можете объяснить? В BOL именно такой пример: Код: sql 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12.
https://docs.microsoft.com/ru-ru/sql/relational-databases/databases/set-a-database-to-single-user-mode?view=sql-server-ver15 Ничего личного, но тут ажно ТРИ примера. Почему именно 1-й? ЗЫ. Как тебе уже доложили, мученик науки, если ты выполняешь приведенный тобой скрипт - никто не может подключиться к базе Владислав Колосов Если этот код выполняется в одном пакете, то как другой сеанс подключится к базе? Значит пакет падает с ошибкой и вы теряете подключение. А ежели у тя ошибка, вырубающая подключение, на что ты жалуешься? SINGLE_USER придуман не для развлекухи - это "опасный" режим. Используя его на работающей, нагруженной базе - надо быть готовым тормозить сервер и использовать выделенное административное подключение. Для твоих сюрплясов - транзакции достаточно. А уж переименование индексов - это за гранью добра и зла. ... |
|||
:
Нравится:
Не нравится:
|
|||
02.02.2022, 11:44 |
|
|
start [/forum/topic.php?fid=46&msg=40131061&tid=1683878]: |
0ms |
get settings: |
9ms |
get forum list: |
14ms |
check forum access: |
4ms |
check topic access: |
4ms |
track hit: |
142ms |
get topic data: |
10ms |
get forum data: |
3ms |
get page messages: |
41ms |
get tp. blocked users: |
1ms |
others: | 15ms |
total: | 243ms |
0 / 0 |