Oracle中dblink应用小结

Oracle应用服务器OS
  1.查看数据库的global_name
        SELECT * FROM GLOBAL_NAME;
 
  2.查看global_name参数是true还是false
       show parameter global_name
       如果为true,本地建立的dblink名称必须与远程的global_name一致才行。
 
  3.创建dblink
       CREATE DATABASE LINK数据库链接名
       CONNECT TO 用户名
       IDENTIFIED BY 密码
       USING ‘数据库连接字符串’;

      例1:CREATE PUBLIC DATABASE LINK CONN_MY_LINK
       CONNECT TO MYUSER IDENTIFIED BY MYPASSWORD
       USING 'MYORAL';
       其中MYORAL为客户端服务器建立的访问服务端服务器的本地命名,
       LINK CONN_MY_LINK为本地建立的dblink名称

       例2:CREATE PUBLIC DATABASE LINK LINK_HSMIS
               CONNECT TO BI
               IDENTIFIED BY BI
              USING '(DESCRIPTION =
                         (ADDRESS_LIST =
                         (ADDRESS = (PROTOCOL = TCP)(HOST = 10.188.245.201)(PORT = 1521))
                          )
                        (CONNECT_DATA =
                        (SERVICE_NAME = hsmis)
                        )
                )';
          直接用本地命名连接字符串替代本地命名。

        // 赋予创建权限
        grant CREATE DATABASE LINK to smis;       
        grant CREATE SYNONYM to smis;
 
  4.查询dblink是否创建成功
      SELECT * FROM DUAL@数据库链接名
      或SELECT * FROM表名@数据库链接名

  5.删除dblink
     drop public database link CONN_MY_LINK

  6.使用同义词简化:
     CREATE SYNONYM S_MY_TABLE FOR TABLENAME@数据库链接名;

  7.db_link查询时出现锁的解决方案
      每次使用db_link查询时释放连接,调用dbms_session包中的关闭函数即可
      例:dbms_session.close_database_link(CONN_MY_LINK);
      或使用dblink的时候,即使是select文也要进行commit,或者是rollback,
      否则时间长了会阻碍其他进程。

  8.查询dblink时出现无法处理服务器名的解决方案
       要在相应的数据库在服务器上建立相应的连接, 如A数据库在A1服务器上,B数据库在b1服务器上,
       如果要在A数据库中连接B数据库,则要在服务器A1上建立相应的tnsnames配置项如下:
     (在Win环境下的Oracle中,Oracle\Network\ADMIN\tnsnames.ora 文件中进行配置)
      A_TO_B =  
      (DESCRIPTION =  
      (ADDRESS_LIST =  
      (ADDRESS = (PROTOCOL = TCP)(HOST =A2服务器的IP)(PORT = 1521)) )        
      (CONNECT_DATA =  
      (SERVICE_NAME = B数据库的服务名)))        
      然后建立相应dblink,容易犯的错误是:
      在自已的客户端的tnsname.ora中建立连接,而没有在A数据库所有的
      服务器A1的tnsname.ora中建立连接。

  9.查看锁表进程和解锁
     (1)方式一:
     select sess.sid,  
     sess.serial#,  
     lo.oracle_username,  
     lo.os_user_name,  
     ao.object_name,  
     lo.locked_mode  
     from v$locked_object lo,  
     dba_objects ao,  
     v$session sess  
     where ao.object_id = lo.object_id and lo.session_id = sess.sid;
     (2)方式二:
      select * from v$session t1, v$locked_object t2
      where t1.sid = t2.SESSION_ID;
     (3)进程解锁  
     如有记录则表示有锁,记录下SID和serial# ,将记录的ID替換下面的SID, serial,即可解除LOCK
     alter system kill session 'SID,serial';

Oracle中dblink如何使用的更多相关文章

  1. oracle 中 dblink 的简单使用

    oracle 中 dblink 的简单使用 dblink的作用 当用户要跨本地数据库,访问另外一个数据库表中的数据时,本地数据库中必须创建了远程数据库的dblink,通过dblink本地数据库可以像访 ...

  2. Oracle中DBLink的使用

    DBLink 的作用是在局域网内,通过一台服务器上面的数据库访问另外一台服务器上面数据库的功能. 下面简单的介绍DBLink的配置: 服务器A:IP 10.10.10.107, 数据库实例名:orcl ...

  3. Oracle中dblink的创建与删除

    查询数据库中有哪些dblink连接 select * from dba_objects where object_type='DATABASE LINK'; 删除公有的EMIS_PRODUCTOIN连 ...

  4. 在oracle中通过链接服务器(dblink)访问sql server

    在oracle中通过链接服务器(dblink)访问sql server 2013-10-16 一.   工作环境: <1> Oracle数据库版本:Oracle 11g  运行环境 :IB ...

  5. oracle中如何创建dblink

    当用户要跨本地数据库,访问另外一个数据库表中的数据时,本地数据库中必须创建了远程数据库的dblink,通过dblink本地数据库可以像访问本地数据库一样访问远程数据库表中的数据.下面讲介绍如何在本地数 ...

  6. Oracle中使用透明网关链接到Sqlserver[Z]

    Oracle中使用透明网关链接到Sqlserver 在最近项目中需要从Oracle中访问SQL Server数据库, 自然想到了透明网关. 因为Oracle数据库是Linux上的, 而Linux上的O ...

  7. MySQL中dblink的实现(通过federated引擎实现)

    最近项目中涉及MySQL数据库视图的创建,需要整合两个位于不同服务器上数据库的内容,就遇到了远程访问数据库的问题.在oracle中可以通过dblink来实现跨本地数据库来访问另外一个数据库中的数据.通 ...

  8. Oracle中使用透明网关链接到Sqlserver(转)

    测试环境介绍 1.ORACLEServer   Database version:10.2.0 IP:192.168.1.5 ORACLE_HOME:D:\oracle\product\10.2.0\ ...

  9. Oracle中Database Link的创建和Synonyms

    在工作中我遇到过这样的一个问题,就是当我需要将远程主机上Oracle数据中某个表的数据copy到本地Oracle时,有多种方法可以实现.1.将所需要的数据导出到csv或其他格式的文档,复制到本地进行直 ...

随机推荐

  1. java中打印输出数组

    import java.util.Arrays; public class ArrayDemo { public static void main(String[] args) { int size ...

  2. 跨进程通信之Messenger

    1.简介 Messenger,顾名思义即为信使,通过它可以在不同进程中传递Message对象,通过在Message中放入我们需要的入局,就可以轻松实现数据的跨进程传递了.Messenger是一种轻量级 ...

  3. centos中NAT模式下静态IP连接外网

    使用linux虚拟机时,通常会用到yum命令来安装软件,然而这个命令需要连外网下载软件,用maven下载jar包也需要外网.虚拟机在内网可以互相ping通,然而ping不了外网,于是通过试验,终于找到 ...

  4. 青出于蓝而胜于蓝 — Vue.js对Angular.js的那些进步

    Angular.js与Vue.js是非常有渊源的两款前端框架,据Vue.js的官方网站描述,在其早期开发时,灵感来源就是Angular.js.而在很多方面,Vue.js也正像是中国的那句古话,&quo ...

  5. ASP.NET Core 2.0 SignalR 示例

    # 一.前言 上次讲SignalR还是在<[在ASP.NET Core下使用SignalR技术](http://dotnet.ren/2017/02/21/%E5%9C%A8ASP-NET-Co ...

  6. SQL SERVER 删除前判断指定的表或者存储过程是否存在

    1.创建存储过程: CREATE PROCEDURE proc_pr ---将create修改成alter可以修改存储过程: AS BEGIN IF EXISTS(SELECT * FROM syso ...

  7. 极客圈(一)树莓派3B协同Python打造个性化天气闹钟

    人生苦短,我用Python~ 一直想自己折腾些极客的东西出来,供自己使用或者是供他人使用.一则可能对自己的生活是一种帮助,二则是对自己技能的提高,三则显得高大上,一直努力,一直提高,一直Happy!~ ...

  8. JavaScript一个cookie存储的类

    所有输出都在浏览器的控制台中 <script type="text/javascript"> /** * cookieStorage.js * 本类实现像localSt ...

  9. python全栈阶段测试(一)

    1.执行Python脚本的两种方式 如果想要永久保存代码,就要用文件的方式 如果想要调试代码,就要用交互式的方式 2.Pyhton单行注释和多行注释分别用什么? 单行注释:# 多行注释: '' &qu ...

  10. [转]从入门到精通: 最小费用流的“zkw算法”

    >>>> 原文地址:最小费用流的“zkw算法” <<<< 1. 网络流的一些基本概念 很多同学建立过网络流模型做题目, 也学过了各种算法, 但是对于基本 ...