Этот баннер — требование Роскомнадзора для исполнения 152 ФЗ.
«На сайте осуществляется обработка файлов cookie, необходимых для работы сайта, а также для анализа использования сайта и улучшения предоставляемых сервисов с использованием метрической программы Яндекс.Метрика. Продолжая использовать сайт, вы даёте согласие с использованием данных технологий».
Политика конфиденциальности
|
|
|
Distributed transaction
|
|||
|---|---|---|---|
|
#18+
Нужно выполнить некоторые действия на 2-х серверах в одной транзакции. Предварительно сервера сконфигурированы для удаленного доступа, то есть запрос вида select * from server2.sql1.dbo.t1 с первого сервера выполняется без проблем. По совету BOL пишу: begin distributed tran insert into server1.sql1.dbo.t1 values (1) insert into server2.sql1.dbo.t1 values (2) commit Запускаю этот код в QA и получаю следующую ошибку: "Could not start a transaction for OLE DB provider 'SQLOLEDB'. [OLE/DB provider returned message: Cannot start more transactions on this session.]" @@rowcount = 0 Дело в каких-нибудь настройках ? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 24.05.2001, 18:12 |
|
||
|
Distributed transaction
|
|||
|---|---|---|---|
|
#18+
Нашлось неплохое решение - использовать stored proc. С ними подобная конструкция работает. begin distributed tran exec server1.sql1.dbo.proc1 exec server2.sql1.dbo.proc1 commit В общем, меня это устраивает, но если кто знает, как в этой ситуации работать не с sp, а с insert..., напишите, пожалуйста. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 24.05.2001, 18:41 |
|
||
|
|

start [/forum/topic.php?fid=46&fpage=3574&tid=1826693]: |
0ms |
get settings: |
8ms |
get forum list: |
18ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
29ms |
get topic data: |
11ms |
get forum data: |
3ms |
get page messages: |
45ms |
get tp. blocked users: |
2ms |
| others: | 224ms |
| total: | 346ms |

| 0 / 0 |
