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

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

创新互联公司是一家专注于成都网站制作、成都网站设计与策划设计,宜章网站建设哪家好?创新互联公司做网站,专注于网站建设十多年,网设计领域的专业建站公司;建站业务涵盖:宜章等地区。宜章做网站价格咨询:18982081108

一、创建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了。此时,你就可以通过在自己的项目中轻松的通过查找同义词或新建的视图来访问客户的数据库服务器中的一些关键数据了。

分享文章:Oracle创建同义词基本方法及其可能遇到的问题
地址分享:http://www.shufengxianlan.com/qtweb/news3/520953.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联