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. PHP运行出现Notice : Use of undefined constant

    这些是 PHP 的提示而非报错,PHP 本身不需要事先声明变量即可直接使用,但是对未声明变量会有提示.一般作为正式的网站会把提示关掉的,甚至连错误信息也被关掉 关闭 PHP 提示的方法 搜索php.i ...

  2. date时间转换

    <!DOCTYPE html> <head> <meta http-equiv="Content-Type" content="text/h ...

  3. 超好用的memcache管理及可视化监控工具,真方便!

    memcache做为主流的缓存数据库之一,广泛在各互联网平台使用,但是大家使用中都知道memcache目前没有一个比较好用的可视化客户端工具,每次都要输入命令进行操作,十分不方便.  而另一款主流缓存 ...

  4. 基于Metronic的Bootstrap开发框架经验总结(15)-- 更新使用Metronic 4.75版本

    在基于Metronic的Bootstrap开发框架中,一直都希望整合较新.较好的前端技术,结合MVC的后端技术进行项目的开发,随着时间的推移,目前Metronic也更新到了4.75版本,因此着手对这个 ...

  5. God 1.1.1 多线程之内存可见性

    共享变量在线程间的可见性 synchronize实现可见性 volatile实现可见性 指令重排序 as-if-serial语义 volatile使用注意事项 synchronized和volatil ...

  6. Struts框架之 执行流程 struts.xml 配置详细

    1.执行流程 服务器启动: 1. 加载项目web.xml 2. 创建Struts核心过滤器对象, 执行filter  →  init()   struts-default.xml,    核心功能的初 ...

  7. mysql常见的优化方法

    1.选取适当的字段属性.例如,在定义邮政编码这个字段时,如果将其设置为CHAR(255),显然给数据库增加了不必要的空间,甚至使用VARCHAR这种类型也是多余的,因为CHAR(6)就可以很好的完成任 ...

  8. jsp实现上一页下一页翻页功能

    前段时间一直忙于期末考试和找实习,好久没写博客了. 这段时间做了个小项目,包含了翻页和富文本编辑器Ueditor的两个知识点,Ueditor玩的还不是很深,打算玩深后再写篇博客. 要实现翻页功能,只需 ...

  9. HTTP模拟工具【C#/Winform源码】、Json绑定TreeView控件、使用了MetroModernUI、RestSharp、Dapper.Net、Newtonsoft.Json、SmartThreadPool这几个主要开源框架

    HTTP模拟工具 开发语言:C#/Winform开发工具:Visual Studio 2017数据库:   SQLite使用框架:界面-MetroModernUI              Http请 ...

  10. Java8 in action(1) 通过行为参数化传递代码--lambda代替策略模式

    [TOC] 猪脚:以下内容参考<Java 8 in Action> 需求 果农需要筛选苹果,可能想要绿色的,也可能想要红色的,可能想要大苹果(>150g),也可能需要红的大苹果.基于 ...