sqlserver cmd连接oracle数据库,sqlserver转oracle(四)oracle新建数据库及夸库连接(database link)...

写在最前面

oracle的多库运行与sqlserver有所不同,oracle会为创建的每个库生成一个服务,如果查看“任务管理器”,我们就会发现这个问题:

74fe56dd3032

多个oracle服务并行

所以,如果库很多,千万别忘了去“服务”里,把主要的oracle服务切换为手动启动。介于oracle服务对内存的占用,最好别建太多库。

考虑到以上问题,我们并没有将原来的多库结构同步到oracle中使用,而是用了两个主库,其他的采用表空间的形式进行。

基本配置及上文

oracle新建数据库

1.在oracle安装目录下,找到Database Configuration Assistant.

2."下一步">"创建数据库">“下一步”>"一般用途或事务处理">"下一步">"输入数据库名及sid",除了配置密码的那一项,其他的都下一步。

新建库基本就是顺着流程指引去做,不在多言。但如果在oracle中进行夸库连接,就不能再像sqlserver中一样直接"database.dbo.table"了。而是需要预先建好一个连接,它是一个公用的,像数据表一样的东西。实际上一旦连接建立成功,在夸库甚至跨服务器的连接上,oracle更加方便。下面,就来建这个连接。

database link建立夸库连接

前提:你所使用的用户名需要具有建立夸库连接的权限。如果你的用户名没有这个权限,那么下面的几步就会帮助你建立这种权限。

一、为用户分配建立database link的权限

1.在命令提示符运行如下命令,使用sys账号登录sqlplus。

sqlplus sys/密码@SID as sysdba

把以上命令中的密码和sid换成自己数据库的信息,比如我的密码是123,数据库的sid是orcl,那么我要运行的是:sqlplus sys/123@orcl as sysdba。

2.连接成功后,依次运行如下命令:

grant create database link to username ; --为username赋予创建私有database link的权限

grant create public database link to username ;--为username赋予创建所有用户可用的database link的权限

grant drop public database link to username; --为username赋予删除database link的权限

上述命令中,username为你正常使用时的用户名。

二、创建database link

用已经有权限的用户登录plsql或者Navicate,如前文中提到的那样。并运行如下命令:

create public database link linkName connect to Tusername IDENTIFIED BY Tpassword using 'connecstr'。

解释:

linkName--随意取名,是这个连接的名字,夸库的时候调用就用linkName。为了便于区分,我一般以_link结尾。

Tusername--要连接的数据库的用户名。

Tpassword--要连接的数据库的密码。

connecstr--.ora文件中的连接字符串,.ora文件一般位于“\product\11.2.0\dbhome_1\NETWORK\ADMIN”目录下。

实例

例如我.ora文件中,要连接的目标库的字符串如下:

(DESCRIPTION =

(ADDRESS = (PROTOCOL = TCP)(HOST =127.0.0.1)(PORT = 1521))

(CONNECT_DATA =

(SERVER = DEDICATED)

(SERVICE_NAME = orcl)

)

)

目标库的名字为:orcl;

可登录目标库的用户名密码分别为: user1和123;

那么,我要建立的夸库连接应运行如下命令:

create public database link orcl_link connect to user1 IDENTIFIED BY 123 using '(DESCRIPTION =

(ADDRESS = (PROTOCOL = TCP)(HOST = 127.0.0.1)(PORT = 1521))

(CONNECT_DATA =

(SERVER = DEDICATED)

(SERVICE_NAME = orcl)

)

)'

这其中,username 和 密码是无需用单引号包裹的。

三、在查询语句中调用

一旦连接建立,在查询语句中的调用将变得非常简单,直接在表后面@linkName就可以。

实例

如果上述的库中有表test1,要通过上述建立的orcl_link去建立连接,我们可以使用如下命令:

select * from test1@orcl_link.

然而在实际使用中,有时这样是会报错的,比如错误信息:

ORA-22992: 无法使用从远程表选择的 LOB 定位器。愿意及解决方案会在另一篇文章中阐述。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值