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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Вставка по dblink через процедуру, ORACLE - > MS SQL2000 
:(
    Опции темы
MasterOfCode
Дата 22.10.2008, 10:14 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


elwin
**


Профиль
Группа: Участник
Сообщений: 740
Регистрация: 24.4.2008
Где: World.Russia.Tyum en

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



Oracle 9.2
MS SQL 2000

Написал процедуру в которой в цикле вставляю по dblink данные в таблицу. 
Выдает ошибку 
ORA-28500
ORA-02063
ORA-06522
Код

create or replace procedure TransferZAK(pFileType in number, pDOB in date)
as
...
begin
     pSQL := 'select aw."WellID" as well_id, sysdate as DOB, r.fileid '||
             'from Well_WellInfo@SHINEDB_BACKUP.US.ORACLE.COM aw,well_lzs.zakloadfilesregister r, well_lzs.zakloadregister l '||
             ' where aw."WellInfoID" = r.WellID and l.registerid = r.registerid and l.registerdate >= ''' || pDOB || '''' ||
             ' and r.filetype = ' || pFileType || '  and '||
             ' r.wellid in (select w."WellInfoID" from Well_WellInfo@SHINEDB_BACKUP.US.ORACLE.COM w)';
                
     open curActTt  for pSQL;
     loop
         fetch curActTt into WellID, DOB, pFileID;
         exit when curActTt%NOTFOUND; 
...
         if (pFileType = 28) then
            insert into ActionTimetable@SHINEDB_BACKUP.US.ORACLE.COM ("WellID", 
                   "DOB", "DOE", "ActionTypeID", 
                   "ActionCauseID", "StateID", "DocID", "Folder", "Tech") 
            values (WellID, DOB, null, 50, null, null, null, null, null);
            
            select max(id) 
            into pActionID 
            from ActionTimetable@SHINEDB_BACKUP.US.ORACLE.COM;
            pSQL_Range := 'select z.top as roof, z.base as bootom, z.n as IsUpward, z.i as IsInflow, '|| 
                                  'z.rash as Discharge, s."ID" as SaturantID, z.sump as TotalDischargePct, '||
                                  'st."ID" as StratumID '||
                          'from well_lzs.zakloadfilesregister r, well_lzs.zakloadregister l, well_lzs.zak_t z, '||
                                'SaturantType@SHINEDB_BACKUP.US.ORACLE.COM s, Stratum@SHINEDB_BACKUP.US.ORACLE.COM st '||
                          'where r.registerid = l.registerid and z.fileid = r.fileid and s."Code"(+) = z.fd and  '||
                                 'st."Code"(+) = z.ist and z.top is not null and z.base is not null and z.fileid = ' || pFileID;
            open curRanges for pSQL_Range;
            loop
                fetch curRanges into pRoof_, pBottom_, pIsUpward, pIsInflow, Discharge_, SaturantID, TotalDischargePct_, StratumID;
                exit when curRanges%notfound;
                pBottom := TO_CHAR(pBottom_, '9999.99');
                pRoof := TO_CHAR(pRoof_, '9999.99');
                Discharge := TO_CHAR(Discharge_, '9999.99');
                TotalDischargePct := TO_CHAR(TotalDischargePct_, '9999.99');
                begin
                   insert into "dbo"."Ranges"@SHINEDB_BACKUP.US.ORACLE.COM ("ActionID",  "Roof", "Bottom")
                   values (pActionID, pRoof, pBottom); --ТУТ СТРЕЛЯЕТ И УЛЕТАЕТ В ЭКСЕПШН БЛОК!!!!!
                exception 
                when others
                then 
                     rollback;
                     raise;
                end;
                select max("ID") 
                into pRangeID
                from Ranges@SHINEDB_BACKUP.US.ORACLE.COM;
                insert into RangeLeaking@SHINEDB_BACKUP.US.ORACLE.COM
                values(pRangeID, pIsUpward, pIsInflow, Discharge, SaturantID, TotalDischargePct, StratumID);
            end loop;
            close curRanges;
         end if;
...
     end loop;
     
     close curActTt;
     commit;



--------------------
user posted image
PM ICQ   Вверх
Zloxa
Дата 22.10.2008, 10:47 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


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

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



Цитата(MasterOfCode @  22.10.2008,  10:14 Найти цитируемый пост)
ORA-28500
ORA-02063
ORA-06522

Безусловно это все объясняет!

ХОтябы текст ошибок привели, чтоли.
По всем перечисленным номерам, возрващаются сообщения от внешней системы.


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


elwin
**


Профиль
Группа: Участник
Сообщений: 740
Регистрация: 24.4.2008
Где: World.Russia.Tyum en

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



user posted image


--------------------
user posted image
PM ICQ   Вверх
MasterOfCode
Дата 22.10.2008, 12:06 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


elwin
**


Профиль
Группа: Участник
Сообщений: 740
Регистрация: 24.4.2008
Где: World.Russia.Tyum en

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



Да, если выполнять все запросы из окна pl/sql developer, все работает нормально. Из процедуры - нет! Весь инет перерыл...  smile 


--------------------
user posted image
PM ICQ   Вверх
Zloxa
Дата 22.10.2008, 12:13 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


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

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



Цитата(MasterOfCode @  22.10.2008,  12:06 Найти цитируемый пост)
Из процедуры - нет

Гранты?
Если процедуру компильнуть с authid current_user, заработает?


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


elwin
**


Профиль
Группа: Участник
Сообщений: 740
Регистрация: 24.4.2008
Где: World.Russia.Tyum en

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



Цитата(Zloxa @  22.10.2008,  15:13 Найти цитируемый пост)
Гранты?

Дело в том что все работало до определённого времени, потом перестало.
Цитата(Zloxa @  22.10.2008,  15:13 Найти цитируемый пост)
Если процедуру компильнуть с authid current_user, заработает? 

Это как?


--------------------
user posted image
PM ICQ   Вверх
Sqlninja
Дата 22.10.2008, 13:44 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 353
Регистрация: 15.5.2006
Где: San Francisco, CA

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



Цитата(MasterOfCode @  22.10.2008,  10:14 Найти цитируемый пост)
 insert into "dbo"."Ranges"@SHINEDB_BACKUP.US.ORACLE.COM ("ActionID",  "Roof", "Bottom")
                   values (pActionID, pRoof, pBottom); --ТУТ СТРЕЛЯЕТ И УЛЕТАЕТ В ЭКСЕПШН БЛОК!!!!!


это че за двойные кавычки?

на удаленной таблице висят какие либо триггеры, которые могут пытаться завершить данную распределенную транзакцию, либо запустить свою автономную?

Это сообщение отредактировал(а) Sqlninja - 22.10.2008, 13:47


--------------------
It's better to burn out than to fade away.
PM MAIL WWW ICQ   Вверх
MasterOfCode
Дата 22.10.2008, 13:48 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


elwin
**


Профиль
Группа: Участник
Сообщений: 740
Регистрация: 24.4.2008
Где: World.Russia.Tyum en

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



Без кавычек не работает.  "dbo"."Ranges" здесь для того чтоб на регистр не ругался. А тут "ActionID",  "Roof", "Bottom" требует сам Oracle. Без них не компилится процедура. Можете быть уверены, синтаксис правельный, процедура работала, не могу понять что явилось причиной ее отказа в работе :(


--------------------
user posted image
PM ICQ   Вверх
Sqlninja
Дата 22.10.2008, 14:01 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 353
Регистрация: 15.5.2006
Где: San Francisco, CA

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



как то непонятно - там есть кавычки, там нету...  а сколько итераций в цикле? на удаленной стороне MSSQL?


--------------------
It's better to burn out than to fade away.
PM MAIL WWW ICQ   Вверх
MasterOfCode
Дата 22.10.2008, 14:05 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


elwin
**


Профиль
Группа: Участник
Сообщений: 740
Регистрация: 24.4.2008
Где: World.Russia.Tyum en

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



Цитата(Sqlninja @  22.10.2008,  17:01 Найти цитируемый пост)
как то непонятно - там есть кавычки, там нету

Это я на самом деле сейчас недавно эксперементировал. Изначально там их не было.

Цитата(Sqlninja @  22.10.2008,  17:01 Найти цитируемый пост)
а сколько итераций в цикле?

разное количество. В зависимости от даты. ну порядка 200-300...

Цитата(Sqlninja @  22.10.2008,  17:01 Найти цитируемый пост)
на удаленной стороне MSSQL? 

Простите, не понял?


--------------------
user posted image
PM ICQ   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "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.0838 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


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

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