现状: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高手指教小弟.将不胜感激.
我利用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,你建触发器的用户是system,那么你建立dblink的用户是system用户吗?2,@SQL是库名字,不是表名字吧,你可以试试SELECT * FROM [email protected]。
你的DBLink是用什么什么用户建立的。用sqlplus和用pl/sql的用户确定是用一个么。
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楼说的问题。
另外不知道你的数据库是不是在本机上?
问1
我在SQLPLUS下用SYSTEM的帐号建DBLINK的.下面是运行结果.
SQL> SELECT * FROM B@SQL; B1 B2
---------- ----------
1 ABC
1 BCD问2
单引写成双引是笔误.
加了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: 要求事务处理或保存点回退
根据这个提示,你不能直接在这里以commit的形式提交,需要savepoint的形式提交或者回滚savepoint a;rollback to savepoint a或者commit to savepoint a;
==================================================================
Inthirties关注Oracle数据库 维护 优化,安全,备份,恢复,迁移,故障处理如果你需要帮助或想和我一起学习的请联系
联系方式QQ:370140387
QQ群: 85837884(注明:数据库)
电子邮件:[email protected]
网站: http://www.inthirties.com
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' 无效且未通过重新确认
触发器里面不能使用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的,要不创建视图就行了)
DBLINK是在SQLPLUS,system的帐号建立的.
ORACLE中触发器能修改SQLSERVER中表的数据吗?
前提是在SQLPLUS中能正常查看SQL的表数据.
至少oracle之间的dblink是这样。
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' 无效且未通过重新确认没有认证是什么问题呢?