十三、分布式ORACLE系统简介 1.分布式体系结构的ORACLE4 {, A k: m& p$ a X& ~
1986年,ORACLE公司推出了它的分布式体系结构的ORACLE数据库系统。该系统是由分布式数据库管理系统(ORACLE RDBMS)、支持多种操作系统和通信协议的分布式处理环境软件SQL*NET、以及与非ORACLE RDBMS联接的软件SQL*CONNECT这三部分组成的一个软件群。分布式ORACLE采用了典型的开放式体系结构,对环境的适应范围非常广泛,可适应多种通信协议、多种操作系统、多种硬件环境及多种DBMS和数据源。
, p. n+ v# f$ L+ B& x$ s. R& P( _' U 2.网络ORACLE的连接过程. J* X% r8 ^3 x5 `# W) V* P7 H) \
网络ORACLE的连接过程大致包括以下几步:0 b* I" \7 s/ ?1 s8 b
(1)确认网络结点是否安装了SQL*NET,如未安装,则需执行:*$SYS@ORACLE:NCONFIG.COM≠进行安装,并且使用SGAPAD.COM重新链接。
. }5 b) J- t) F+ Y (2)确认安装中选取的网络驱动器与操作系统环境下所配置的通信协议是否相符。(3)待(1)、(2)两项均确认后,则可在服务器(Server)结点上建立一个命令文件。这个命令文件主要完成以下工作:指定ORACLE系统标识码SID,从而确定将哪一个ORACLE RDBMS作为服务器。这是因为同机上可运行多个ORACLE RDBMS,指定方式为:$ASSIGN〈SID标识码〉ORACLE$SID指定ORACLE系统所在目录:$ASSIGN〈目录名〉SYS$ORACLE指定SQL*NET执行代码的逻辑名$ORASRV=SYS$ORACLE:ORASRV.EXE启动SQL*NET的执行代码$ORASRV DECNET-NSP:
% D! s2 r7 U# c4 J0 f (4)待完成以后,用户即可进行远程访问。(注意两个结点上的ORACLE系统应处于开启状态)
" z8 f; n0 C0 U0 X) g7 M" Z; a/ t (5)为了加强网络通信管理和避免冲突等原因,可以通过VAX/VMS网络控制程序NCP建立一和于ORACLE网络通信的缺省帐号。
" u/ a, ]; r' U) w0 m 3.网络ORACLE的使用
$ |% Y: W8 ~) y8 m4 l% P/ U 除了以下实用程序以外,其它ORACLE实用程序和软件工具均可以通过SQL*NET访问远程结点的ORACLE系统IOR AJI仅供本地使用。另外,用户通过各种语言编写的应用程序也可以进行远程存取。用户远程存取的方式非常简单,仅需要在“用户名/口令”(ORACLE的合法用户)后面附上结点信息。5 u! W* }0 b3 G0 y6 H6 o* A- [) p4 v
4.分布式查询
5 O! j1 O( w& C9 w, ?* l& Q 分布式查询和数据传输,主要指用户在前端机上执行本地的进程通过SQL语句或SQLplus命令查询或传输远程结点上的数据。由于网络ORACLE系统的分布式查询功能很强,用户可以同时查询多个结点上的数据库数据。传输数据功能用于两个结点之间数据及定义的复制,下面将分别介绍。ORACLE系统分布式查询的功能使得一个结点上的用户可以通过SQL查询语句访问其它结点数据库的数据。并且用户还可以同时存取访问多个结点(包括本地结点)的数据,从而使数据库的查询功能大大增强。
! N$ a& m9 O" q. z0 B (1)数据库链路(DATABASE LINK)为了使分布式查询操作更加简单方便,ORACLE RDBMS为用户提供了一个新的数据定义方式:数据库链路。用户可以通过数据库链路定义,在本地结点和远程之间进行查询和连接。进行远程访问的用户需要明确:远程数据库所在的结点;远程结点上的哪个数据库;远程数据库的哪个用户。数据库链路即用于标识以上内容。用户通过SQL的CREATE DATABASE LINK语句定义数据库链路。其格式为:CREATE[PUBLIC]DATABASE LINK链路名CONNECT TO用户名INENTIFIED BY口令USING‘驱动器前缀:结点名““操作系统用户名口令”””::“““TASK=ORDN后缀.COM”””;如果用户事先定义一个逻辑名:$ASSIGN结点名,“““操作系统用户名口令”””::“““TASK=ORDN后缀.COM”””,逻辑名那么CREATE DATABASE LINK就变得十分简洁:CREATE[PUBLIC]DATABASE LINK链路名CONNECT TO用户名IDENTIFIED BY口令USING‘驱动器前缀:逻辑名’;这里PUBLIC代表公用数据库链路,只有DBA才能使用PUBLIC限定词。7 N" _( ~9 n. p/ Q6 e
(2)远程查询操作在数据库链路定义以后,远程查询就变得非常简单和方便。用户访问查询数据库的表或视图时,只要在表名或视图名后面附上数据库链路名即可通过SELECT语句进行查询。其形式为:SELECT列表达式[,列表达式,…] FROM表名@数据库链路名[,表名@数据库链路名,…] [WHERE逻辑表达式];) t4 P7 ~, L, B( J* c
(3)定义同义名用户可以用同义名来简化一些繁琐的表名或视图名。对于远程查询操作,用户也可以为远程数据库的表名或视图名定义相应的同义名。
2 m/ B5 b ?& ]3 Z. C8 t (4)连接操作在远程查询中,用户可以连接相同(或不同)结点上数据库中的表。连接(JOIN)操作可以针对以下情况:同一数据库中的两个表或多个表;同一结点不同数据库中的两个表或多个表;不同结点上数据库中的两个表或多个表;
% z, @/ C6 w8 ?' [& j (5)查询远程数据库中其他用户的数据用户在通过数据库链路进行远程查询时,可以访问其他用户的数据。数据库链路的定义中指定一个远程用户名及口令,这个用户名被称为链路用户名。上面所述的“其他用户”即指非链路用户。如果链路用户具有访问其他某一用户,记为用户A的权限,那么,Client用户就可以通过数据库链路查询服务器用户A中的数据。" z3 n$ ]% @, W8 L( Q
2 m$ X4 _$ y1 T/ m6 Q* O (6)远程子查询前面介绍的是基于主查询的远程访问。事实上,SQL语句中的子查询(Sub-query)也可以访问远程结点的数据库数据。这种子查询称为远程子查询。可嵌入查询的语句有:SELECT INSERT UPDATE CREATE TABLE CREATE VIEW |