软件测试开发技术之数据库基础:教你轻松掌握数据库链路的建立和使用[2]

发表于:2009-09-14来源:作者:点击数: 标签:软件测试数据库开发基础技术
软件测试 开发 技术之数据库基础:教你轻松掌握数据库链路的建立和使用[2] 数据库设计 关键字: 4、查看所有的数据库链接,进入系统管理员SQL操作符下,运行命令: SQLselect owner,object_name from dba_objects where object_type='DATABASE LINK'; 如果子

软件测试开发技术之数据库基础:教你轻松掌握数据库链路的建立和使用[2]  数据库设计

关键字:

4、查看所有的数据库链接,进入系统管理员SQL>操作符下,运行命令:

  SQL>select owner,object_name from dba_objects where object_type='DATABASE LINK';

  如果子使用数据连接出现错误ORA-02085

  SQL> SHOW PARAMETER GLOBAL_NAMES
  global_names boolean
  TRUE
  SQL> ALTER SYSTEM SET GLOBAL_NAMES=FALSE;

  简单查了一下,Piner的faq上没有,前面也没有人提到。

  使用数据连接可以很方便的引用其它数据库的数据,但是设置不当可能遇到ORA-02085错误。如果被连接对方的GLOBAL_NAMES参数设置成了TRUE,那么要求数据库连接与对方实例名有相同的名称。这样就可以通过下面3中的任意一种方法来解决:

  1.修改对方的GLOBAL_NAMES参数为FALSE

  2.将对方的GLOBAL_NAME设置成与数据库连接相同的名称

  3.将数据库连接删掉重新创建成与对方实例名相同的数据库连接。下面是测试结果:

  SQL> CREATE PUBLIC DATABASE LINK "MASTER.COM" USING 'ORA9I';

  数据库链接已创建。

  SQL> SELECT * FROM DUAL@MASTER.COM;
  SELECT * FROM DUAL@MASTER.COM
  *

  ERROR 位于第 1 行:

  ORA-02085: 数据库链接MASTER.COM与ORA9I相连结

  SQL> SHOW PARAMETER GLOBAL_NAMES
  global_names boolean
  TRUE
  select * from v$parameter where name = 'global_names';
  SQL> ALTER SYSTEM SET GLOBAL_NAMES=FALSE;
  或者修改D:\Oracle\admin\einfo\pfile\init.ora文件中global_names = false,重启数据库。
  SQL> SELECT * FROM DUAL@MASTER.COM;
  X
  SQL> ALTER SYSTEM SET GLOBAL_NAMES=TRUE;

  系统已更改。

  SQL> SELECT * FROM DUAL@MASTER.COM;
  SELECT * FROM DUAL@MASTER.COM
  ERROR 位于第 1 行:

  ORA-02085: 数据库链接MASTER.COM与ORA9I相连结

  SQL> ALTER DATABASE RENAME GLOBAL_NAME TO MASTER.COM;

  数据库已更改。

  SQL> SELECT * FROM DUAL@MASTER.COM;

原文转自:http://www.ltesting.net