Модераторы: LSD
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> [PL/SQL] Распределенные транзакции, использование db links 
:(
    Опции темы
Girin
Дата 3.3.2010, 14:03 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 81
Регистрация: 6.2.2008

Репутация: нет
Всего: нет



Добрый день. Проблема следующая:
Есть хранимая процедура на моей базе (Oracle 10g) которая через dblink дергает хранимку из другой базы. То есть 
Код

procedure test_remote_function
IS 
res NUMBER;
BEGIN
res:=0;
pr_update@remdb_link(res=>res);
EXCEPTION WHEN
OTHERS THEN
raise_application_error(-20002,'ERROR Occured: '||SQLCODE||' - '||SQLERRM);
END test_remote_function;
 При вызове этого кода вылетает эксепшен
Код

ORA-02064 - distributed operations not supported

 Удаленная процедура, выполняет обновление таблиц своей базы. Читал что способы борьбы с ошибкой это отказ от использования явных commit/rollback в теле удаленной хранимки, но для меня недоступно ее изменение. Также есть информация что следует использовать pragma autonomous_transaction - пробовал не помогает. Как еще можно обойти это проблему ? 
PM   Вверх
Zloxa
Дата 3.3.2010, 15:02 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


Профиль
Группа: Завсегдатай
Сообщений: 3473
Регистрация: 12.9.2008

Репутация: 37
Всего: 161



Цитата(Girin @  3.3.2010,  14:03 Найти цитируемый пост)
 Как еще можно обойти это проблему ? 

Написань хранимку на жаве, которая, используя собственное подключение к удаленному серверу, выполняла бы этот вызов.
Это лишь как идея, не более.

Добавлено через 6 минут и 40 секунд
Цитата(Girin @  3.3.2010,  14:03 Найти цитируемый пост)
пробовал не помогае

Не помогает где?
Еще как вариант, на удаленном сервере реализовать другую  процедуру, которая вполняла бы вызов нужной в автономной транзакции.  И от себя дергать эту процедуру.
Если вы не можете менять текст процедуры, это ведь не всегда значит, что вы не можете создать собственную процедуру, пусть и в другой схеме но в той же базе.

Это сообщение отредактировал(а) Zloxa - 3.3.2010, 15:03


--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
Girin
Дата 3.3.2010, 15:35 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 81
Регистрация: 6.2.2008

Репутация: нет
Всего: нет



Про вариант с Java хранимкой тоже пробовал, неудобно что надо зашивать параметры соединения,
которые могут меняться. 

Цитата(Zloxa @  3.3.2010,  15:02 Найти цитируемый пост)
Цитата(Girin @  3.3.2010,  14:03 )
пробовал не помогае

Не помогает где?

Не помогает если в начале тела моей хранимки на pl/sql подставить данное выражение то есть:
Код

procedure test_remote_function
IS 
pragma autonomous_transaction
res NUMBER;
BEGIN
res:=0;
..........




Цитата(Zloxa @  3.3.2010,  15:02 Найти цитируемый пост)
Еще как вариант, на удаленном сервере реализовать другую  процедуру, которая вполняла бы вызов нужной в автономной транзакции.  И от себя дергать эту процедуру.
 Вот это очень интересный вариант, не догадался. Попробую, спасибо

PM   Вверх
Girin
Дата 5.3.2010, 16:43 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 81
Регистрация: 6.2.2008

Репутация: нет
Всего: нет



Если кому то интересно, проблема решилась возвратом к исходному варианту - вызов удаленных процедур без использования явных коммитов после их вызова, и всяких прагм
PM   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Oracle"
Zloxa
LSD

Данный раздел предназначен для обсуждения проблем с Oracle Database, другие продукты Oracle здесь не обсуждаются. Просьба при создании темы, придерживаться следующих правил:

  • при создании темы давайте ей осмысленное название, описывающее суть проблемы
  • указывайте используемую версию базы, способ соединения и язык программирования
  • при ошибках обязательно приводите код ошибки и сообщение сервера
  • приводите код в котором возникла ошибка, по возможности дайте тестовый пример демонстрирующий ошибку
  • при вставке кода используйте соответсвующие теги: [code=sql] [/code] для подсветки SQL и PL/SQL кода, [code=java] [/code] - для Java, и т.д.

  • документация по Oracle: 9i, 10g, 11g
  • книги по Oracle можно поискать здесь
  • действия модераторов можно обсудить здесь

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Zloxa, LSD.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Oracle | Следующая тема »


 




[ Время генерации скрипта: 0.0827 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.