Oracle创建同义词基本方法及其可能遇到的问题

数据库 Oracle
文章介绍了Oracle创建同义词的方法,以及中间可能遇到的问题及其解决方法。希望能提供在一种解决类似问题的思路,供大家借鉴。

很多客户有属于自己的数据库服务器,来管理自己的一些重要数据。那如果我们的项目中需要用到这些数据,而客户又不允许把这些数据插入到我们的项目数据库服务器时怎么办?其中的一个解决办法就是在项目数据库服务器上创建基于客户关键数据服务器的某些表或是视图的同义词。这里来介绍一下本人在项目中做的基于远程服务器视图如何对Oracle创建同义词的过程。

一、创建database link。两台不同的数据库服务器,从项目数据库服务器的一个用户读取客户关键数据的数据库服务器下的某个用户的数据,这个时候可以使用dblink。假设客户提供的数据库服务器信息如下:
而创建database link的语法为:
这时,先要配置本地服务。打开TNSNAMES.ORA Network Configuration File: D:\ORA\NETWORK\ADMIN\tnsnames.ora文件(根据自己的机器的情况而定),将
LIMSTQ =
  (DESCRIPTION =
    (ADDRESS_LIST =
      (ADDRESS = (PROTOCOL = TCP)(HOST = 10.107.6.15)(PORT = 1521))
    )
    (CONNECT_DATA =
      (SERVICE_NAME = VGSM)
    )
  )
添加到此文件的后面(注意LIMSTQ前面不要留空格)。

然后,再创建dblink。而数据库参数global_name=true时,就要要求数据库链接名称跟远端客户数据库名称一样。我们必须先要确定一下。查看此参数的语句如下:如果是ture,记得创建的dblink名和远程端的数据库一样,很幸运,我用的数据库参数global_name的value值是false。

数据库全局名称可以通过以下命令查出:查询远端数据库里的表:这时,我就创建了自己的databae link:create database link limstq.us.oracle.com connect to jlgl identified by jlgl using 'limstq';

二、Oracle创建同义词,很简单。Oracle建立同义词的语法如下:
所建立的同义词语法是:create synonym jl_gljs_tb_lims for JLGL_LIMS@limstq.us.oracle.com;

三、Oracle创建同义词成功后,就可以在项目数据库服务器上通过select jl_gljs_tb_lims来进行客户的关键数据的查找操作了。但如果可能的话,***再建立一个视图,形式如下:create or replace view jl_gljs_limstq_vw as select * from jl_gljs_tb_lims;这样,基于远程服务器视图的Oracle创建同义词过程就完成了。

可能遇到的问题:如果你在Oracle创建同义词过程中发现了像如下的不能连接的错误的话,一定会很郁闷吧。ORA-12154: TNS: 无法解析指定的连接标识符。而你通过查看ora文件,发现自己已经配了TNS的。这也是令我头疼的问题。你一定要看清楚了,一定要把本地服务创建到项目数据库服务器的主服务器的ora文件中,而不是自己的客户端的ora文件中。你可能正在使用pl/sql或是sql plus等工具,但是你所用的机器是客户端,而不是真正的项目主服务器(除非在自己的机器上创建的是oracle)。只有找到主服务器ora文件,将本地服务配置到里面,才算ok了。此时,你就可以通过在自己的项目中轻松的通过查找同义词或新建的视图来访问客户的数据库服务器中的一些关键数据了。
 

【编辑推荐】

  1. Oracle创建存储过程不得不看的方案
  2. Oracle创建相关的存储过程最有效的方法
  3. Oracle创建表空间的代码示例
  4. Oracle创建删除用户的实际操作步骤
  5. Oracle创建表空间的实操 

 

责任编辑:王婧瑶 来源: 互联网
相关推荐

2010-04-22 14:29:12

Oracle同义词

2010-05-04 14:02:53

Oracle同义词

2011-04-13 16:39:43

2010-04-22 14:55:39

2021-07-05 11:30:04

OracleSynonymORA

2021-01-19 08:09:04

Oracle数据库权限

2010-05-06 09:09:13

Oracle同义词

2011-08-12 12:59:33

Oracle数据库同义词

2011-08-02 17:06:29

Oracle远程数据库创建DB Link

2019-01-07 14:36:36

Go系统开源库

2024-10-08 09:19:03

2017-09-27 15:20:23

PHPerLaravelMysql

2010-03-31 15:38:33

Oracle用户

2010-10-26 16:33:54

创建Oracle索引

2010-04-23 13:01:43

Oracle报表

2010-04-21 17:09:28

Oracle启动模式

2011-05-20 10:05:13

Oracle性能优化

2009-04-24 10:49:57

Oracle性能优化错误

2016-03-23 11:03:40

2010-04-22 15:46:58

Oracle监听
点赞
收藏

51CTO技术栈公众号