Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 324|回复: 0

DatabaseLink的创建和Oracle11G的问题解决

[复制链接]
  • TA的每日心情
    奋斗
    2024-4-6 11:05
  • 签到天数: 748 天

    [LV.9]以坛为家II

    2034

    主题

    2092

    帖子

    70万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    705612
    发表于 2021-5-11 20:47:37 | 显示全部楼层 |阅读模式

    本文实例讲述了oracle跨库查询dblink的用法。分享给大家供大家参考,具体如下:

    1.创建之前的工作

    在创建dblink之前,首先要查看用户是否有相应的权限。针对特定的用户,使用 sqlplus user/pwd登录后,执行如下语句:

    select * from user_sys_privs t where t.privilege like upper('%link%');

    在sys用户下,显示结果为:

     

    SYS CREATE DATABASE LINK NO
    SYS DROP PUBLIC DATABASE LINK NO
    SYS CREATE PUBLIC DATABASE LINK NO

    可以看出在数据库中dblink有三种权限:

    CREATE DATABASE LINK--所创建的dblink只能是创建者能使用,别的用户使用不了
    CREATE PUBLIC DATABASE LINK--public表示所创建的dblink所有用户都可以使用
    DROP PUBLIC DATABASE LINK--删除指定dblink

    如果想要改变某个用户的权限,需要在sys用户下修改:

    grant CREATE PUBLIC DATABASE LINK,DROP PUBLIC DATABASE LINK to scott;

    查看dblink,有两种方式,分别如下:

     

    ①.

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

    ②.

    select * from dba_db_links;

    2. 创建dblink

    create public database link LINK_NAME
    connect to USRNAME identified by PASSWORD
    using 
    '(DESCRIPTION =(ADDRESS = (PROTOCOL = TCP)(HOST = XXX.XXX.XXX.XXX)(PORT = 1521))
    (CONNECT_DATA =(SERVER = DEDICATED)(SERVICE_NAME = XXX))
     )';

    注意:using后跟的是一个字符串,其中一定不要出现不必要的空格,否则会出错ORA-12514,在上面的代码中为了方便阅读其中进行了换行,可能会出现空格而导致错误,所以使用的时候将空格去掉就ok了。

    这里LINK_NAM为自定的名称;USERNAME和PASSWORD为指定的oracle数据库中的用户名和密码,SERVICE_NAME如果不确定的话,可以通过以下语句获得:

    show parameter service_names;

    或者

    select name,value from v$parameter where name='service_names'

    3.dblink的使用

    dblink的使用相对比较简单,把一般访问本地表时的表名改为如下格式即可:[user.]table@link_name。

    select studentid from abc.studeng@abc_ten;

    4.删除dblink

     

    确定要删除的dblink名字以后,可以通过drop命令直接将其删除:

    drop public database link abc_ten;

     

    oracle 11gR2 本地能连接上,远程连接不上,错误码:ORA-12541 TNS 无监听程序

     

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2024-5-16 01:18 , Processed in 0.067361 second(s), 29 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表