写在最前面
oracle的多库运行与sqlserver有所不同,oracle会为创建的每个库生成一个服务,如果查看“任务管理器”,我们就会发现这个问题:
。
所以,如果库很多,千万别忘了去“服务”里,把主要的oracle服务切换为手动启动。介于oracle服务对内存的占用,最好别建太多库。
考虑到以上问题,我们并没有将原来的多库结构同步到oracle中使用,而是用了两个主库,其他的采用表空间的形式进行。
基本配置及上文
1.sqlserver转oracle(一) oracle创建用户
2.sqlserver转oracle(二) Navicate连接oracle
3.sqlserver转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 定位器。愿意及解决方案会在另一篇文章中阐述。