设为首页 收藏本站
查看: 504|回复: 0

[经验分享] ORA-02069同时使用数据库链和序列时应注意的几点

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2015-11-8 12:10:00 | 显示全部楼层 |阅读模式
  Error: ORA-02069: global_names parameter must be set to TRUE for this operation
Cause: You tried to execute an operation that requires a remote mapping. This can not be done because the parameter called GLOBAL_NAMES is not set to TRUE.
Action: The options to resolve this Oracle error are:
Try setting the GLOBAL_NAMES parameter to TRUE with the following statement:
ALTER SESSION SET GLOBAL_NAMES = TRUE;
  
在一条语句中如果同时包括数据库链和序列,就会出现潜在的问题,而Oracle的文档在这里并没有描述清楚。
  下面通过一个例子对同时包括数据库链和序列的几种情况分别进行说明。
  
  首先,构造一个测试的环境(两个数据库的GLOBAL_NAMES均为TRUE):
  SQL> conn scott/tiger@yangtk
已连接。
SQL> create table test_on_yangtk (id number);
  表已创建。
  SQL> insert into test_on_yangtk values (1);
  已创建 1 行。
  SQL> commit;
  提交完成。
  SQL> create sequence seq_on_yangtk;
  序列已创建。
  SQL> conn yangtk/yangtk@test4
已连接。
SQL> create table test_on_test4 (id number);
  表已创建。
  SQL> insert into test_on_test4 values (1);
  已创建 1 行。
  SQL> commit;
  提交完成。
  SQL> create sequence seq_on_test4;
  序列已创建。
  SQL> create database link yangtk connect to scott identified by tiger using 'yangtk';
  数据库链接已创建。
  对于简单的查询语句,可以分为四种情况。
  1.从本地表中读取数据,并引用本地序列。
  SQL> select seq_on_test4.nextval from test_on_test4;
  NEXTVAL
----------
         1
  2.从本地表中读取数据,但访问远端序列,这时,需要在序列后面加上数据库链名称。
  SQL> select seq_on_yangtk.nextval@yangtk from test_on_test4;
  NEXTVAL
----------
         1
  3.读取远端数据表中数据,同时访问远端序列。
  SQL> select seq_on_yangtk.nextval@yangtk from test_on_yangtk@yangtk;
  NEXTVAL
----------
         2
  4.读取远端数据表中数据,但是访问本地序列。
  SQL> select seq_on_test4.nextval from test_on_yangtk@yangtk;
  NEXTVAL
----------
         2
  通过测试,这四种情况工作都很正常。
  下面,考虑分布式事务——以INSERT INTO SELECT为例。
  由于INSERT的表可以是本地表,也可以是远端表,对于每种情况,对应的子查询语句都可能包含上面四种情况,下面就一一进行分析。
  一、插入本地表
  1.从本地表中读取数据,并引用本地序列
  SQL> insert into test_on_test4 select seq_on_test4.nextval from test_on_test4;
  已创建 1 行。
  SQL> rollback;
  回退已完成。
  2.从本地表中读取数据,但访问远端序列
  SQL> insert into test_on_test4 select seq_on_yangtk.nextval@yangtk from test_on_test4;
  已创建 1 行。
  SQL> rollback;
  回退已完成。
  3.读取远端数据表中数据,同时访问远端序列。
  SQL> insert into test_on_test4 select seq_on_yangtk.nextval@yangtk from test_on_yangtk@yangtk;
  已创建 1 行。
  SQL> rollback;
  回退已完成。
  4.读取远端数据表中数据,但是访问本地序列。
  SQL>  insert into test_on_test4 select seq_on_test4.nextval from test_on_yangtk@yangtk;
  已创建 1 行。
  SQL> rollback;
  回退已完成。
  经测试,插入本地表的四种情况,没有出错。
  二、插入远端表
  1.从本地表中读取数据,并引用本地序列
  SQL> insert into test_on_yangtk@yangtk select seq_on_test4.nextval from test_on_test4;
insert into test_on_yangtk@yangtk select seq_on_test4.nextval from test_on_test4
*
ERROR 位于第 1 行:
ORA-02289: 序列(号)不存在
ORA-02063: 紧接着line(源于TEST4)
ORA-02063: 紧接着2 lines(源于YANGTK)
  2.从本地表中读取数据,但访问远端序列
  SQL> insert into test_on_yangtk@yangtk select seq_on_yangtk.nextval@yangtk from test_on_test4;
  已创建 1 行。
  SQL> rollback;
  回退已完成。
  3.读取远端数据表中数据,同时访问远端序列。
  SQL> insert into test_on_yangtk@yangtk select seq_on_yangtk.nextval@yangtk from test_on_yangtk@yangtk;
  已创建 1 行。
  SQL> rollback;
  回退已完成。
  4.读取远端数据表中数据,但是访问本地序列。
  SQL> insert into test_on_yangtk@yangtk select seq_on_test4.nextval from test_on_yangtk@yangtk;
insert into test_on_yangtk@yangtk select seq_on_test4.nextval from test_on_yangtk@yangtk
*
ERROR 位于第 1 行:
ORA-02289: 序列(号)不存在
ORA-02063: 紧接着line(源于TEST4)
ORA-02063: 紧接着2 lines(源于YANGTK)
  根据测试,第一种情况和第四种情况出现了相同的错误。
  在和其他所有没有报错的情况比较后,可以得到这样的结论:当插入远端数据表,并使用本地序列时会出现错误。  
  Oracle的error文档上这样描述2289错误的:
  ORA-02289 sequence does not exist
Cause: The specified sequence does not exist, or the user does not have the required privilege to perform this operation.
Action: Make sure the sequence name is correct, and that you have the right to perform the desired operation on this sequence.
  根据目前的错误以及Oracle给出的错误原因,初步怀疑对于这种插入远端数据表的分布式事务,实际上是在远端上执行的。因此YANGTK上的scott用户找不到SEQ_ON_TEST4这个序列。
  给YANGTK上的scott用户增加一个指向TEST4上yangtk用户的数据库链。
  SQL> conn scott/tiger@yangtk
已连接。
SQL> create database link test4 connect to yangtk identified by yangtk using 'test4';
  数据库链接已创建。
  SQL> conn yangtk/yangtk@test4
已连接。
SQL> insert into test_on_yangtk@yangtk select seq_on_test4.nextval from test_on_test4;
  已创建 1 行。
  SQL> rollback;
  回退已完成。
  SQL> insert into test_on_yangtk@yangtk select seq_on_test4.nextval from test_on_yangtk@yangtk;
  已创建 1 行。
  SQL> rollback;
  回退已完成。
  建立数据库链之后,重新执行错误的语句,这次执行没有出现错误。
  如果在一条语句中同时使用数据库链和序列,这时候应当小心,你可能不仅需要一条到远端的数据库链,还可能需要一个从远端到本地的数据库链。
  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-136577-1-1.html 上篇帖子: 执行ST_Geometry操作提示“ORA-06522: Unable to load symbol from DLL” 下篇帖子: ORA-19606: 无法复制到 (或还原为) 快照控制文件
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表