现状:oracle9i的表A,sqlserver2000的表B
我利用oracle的透明网关,建立的DBLINK(ORACLE->SQLSERVER)为"SQL";
在SQLPLUS中运行SELECT * FROM B@SQL的命令是可以运行.出现了我需要的数据结果.
问题:
我现在想通过ORACLE的A表的UPDATE中"B1"列名来修改SQLSERVER的B表中相对应"A1"列名的值.
其中A表的B2是对应B表中的A2
A表              B表
A1     A2      B1       B2
---   ----    -----    -------
0      ABC     0        ABC
1      BCD     1        BCD
我建了一个触发器.
create or replace trigger tr_Aupdate
after update on system.A for each row
begin
 update B@sql set "B1"=:new.a1 where "B2"=:old.a2
end tr_Aupdate;
--------------------------
update system.A set A1=2 where A2="BCD";
select * from system.A where  A2="BCD";
A1     A2        B1       B2
---   ----     -----    -------
2      BCD       1        BCD
SELECT * FROM B@SQL;
B1     B2
---   ---- 
0      ABC   
1      BCD
在PLSQL中使用SELECT * FROM B@SQL提示ORA-02019:未找到远程数据库的连接说明.
我在往上也搜索了"ORA-02019"的信息及解决方法.但没有找到想要的结果和解决方法
请ORACLE高手指教小弟.将不胜感激.

解决方案 »

  1.   


    1,你建触发器的用户是system,那么你建立dblink的用户是system用户吗?2,@SQL是库名字,不是表名字吧,你可以试试SELECT * FROM [email protected]
      

  2.   

    dblink没有用过,按照自己的理解说的,不当之处请附赠!
      

  3.   


    你的DBLink是用什么什么用户建立的。用sqlplus和用pl/sql的用户确定是用一个么。
      

  4.   

    在oracle上建@sql表的同义词吧,这样就不用每次都考虑表的owner的问题
      

  5.   

    楼主好像有两个问题是不是?1. 触发器没用,因为B表的B1没有改为2
    2. pl/sql developer里面不能执行SELECT * FROM B@SQL,而在sqlplus里面是可以的。
    实际上还有问题:
    update system.A set A1=2 where A2="BCD"; 
    select * from system.A where  A2="BCD";这两个语句用了双引号都会报错吧? 还是只是发帖时的笔误而已?
    第1个问题:
    执行update system.A set A1=2 where A2='BCD'; 的时候有没有因为触发器的原因报错?第2个问题:
    如果dblink创建时没有指定为public,需要检查3楼说的问题。
    另外不知道你的数据库是不是在本机上? 
      

  6.   

    回答:
    问1
    我在SQLPLUS下用SYSTEM的帐号建DBLINK的.下面是运行结果.
    SQL>  SELECT * FROM B@SQL;        B1 B2
    ---------- ----------
             1 ABC
             1 BCD问2
    单引写成双引是笔误.
      

  7.   


    加了COMMIT后
    -------------------------------
    SQL> update system.A set A1=2 where A2="BCD"; 
    update system.A set A1=2 where A2="BCD"
                  *
    ERROR 位于第 1 行:
    ORA-00604: 递归 SQL 层 1 出现错误
    ORA-02067: 要求事务处理或保存点回退
      

  8.   


    根据这个提示,你不能直接在这里以commit的形式提交,需要savepoint的形式提交或者回滚savepoint a;rollback to savepoint a或者commit to savepoint a;
    ==================================================================
    Inthirties关注Oracle数据库 维护 优化,安全,备份,恢复,迁移,故障处理如果你需要帮助或想和我一起学习的请联系
    联系方式QQ:370140387
    QQ群:  85837884(注明:数据库)
    电子邮件:[email protected]
    网站: http://www.inthirties.com
      

  9.   

    现在又提示新的问题
    SQL>  update system.A set A1=2 where A2='BCD'; 
     update system.A set A1=2 where A2='BCD'
                   *
    ERROR 位于第 1 行:
    ORA-04098: 触发器 'SYSTEM.TR_AUPDATE' 无效且未通过重新确认
      

  10.   


    触发器里面不能使用commit的,假设一个插入或更新的触发器使用了commit,那么我回滚了插入或更新操作,触发器里的动作已经提交了,不可能回滚了,这样事务的完整性就破坏了如果非得在触发器里执行提交操作的话,只能用自治事务了用system帐号建立的DBLINK,那么在PL/SQL里以system帐号登录,也是能够执行SELECT * FROM B@SQL; 能够正常看到查询结果检查创建的DBLINK(名字叫SQL的)是private 还是public的,如果是私有的,那么仅仅只有system帐号能够访问这个DBLINK;如果是公有的,那么所有帐户都能访问(私下估计楼主创建trigger的用户不是system,且DBLINK是私有的)
    trigger是用哪个帐号建立的?建立trigger帐号是否能够执行SELECT * FROM B@SQL; 如果不能,重建一个公有的DBLINK吧(楼主需要更新操作,所以只能重建一个public的,要不创建视图就行了)
      

  11.   


    DBLINK是在SQLPLUS,system的帐号建立的.
      

  12.   

    请教高手们
    ORACLE中触发器能修改SQLSERVER中表的数据吗?
    前提是在SQLPLUS中能正常查看SQL的表数据.
      

  13.   

    如果连接到的用户有更新权限的话,应该是可以修改的吧。
    至少oracle之间的dblink是这样。
      

  14.   


    SQL> update system.a set a1=2 where a2='bcd';
    update system.a set a1=2 where a2='bcd'
                  *
    ERROR 位于第 1 行:
    ORA-04098: 触发器 'SYSTEM.TR_AUPDATE' 无效且未通过重新确认没有认证是什么问题呢?