服务器

位置:IT落伍者 >> 服务器 >> 浏览文章

怎样使两台服务器的oracle9i的数据同步


发布日期:2023年06月04日
 
怎样使两台服务器的oracle9i的数据同步

高机复制就是物化视图

物化视图是包括一个查询结果的数据库对像它是远程数据的的本地副本或者用来生成基于数据表求和的汇总表物化视图存储基于远程表的数据也可以称为快照

物化视图可以查询表视图和其它的物化视图

通常情况下物化视图被称为主表(在复制期间)或明细表(在数据仓库中)

对于复制物化视图允许你在本地维护远程数据的副本这些副本是只读的如果你想修改本地副本必须用高级复制的功能当你想从一个表或视图中抽取数据时你可以用从物化视图中抽取

对于数据仓库创建的物化视图通常情况下是聚合视图单一表聚合视图和连接视图

本篇我们将会看到怎样创建物化视图并且讨论它的刷新选项

在复制环境下创建的物化视图通常情况下主键rowid和子查询视图

主键物化视图

下面的语法在远程数据库表emp上创建主键物化视图

SQL> CREATE MATERIALIZED VIEW mv_emp_pk

REFRESH FAST START WITH SYSDATE

NEXTSYSDATE + /

WITH PRIMARY KEY

AS SELECT * FROM emp@remote_db;

Materialized view created

注意当用FAST选项创建物化视图必须创建基于主表的视图日志如下:

SQL> CREATE MATERIALIZED VIEW LOG ON emp;

Materialized view log created

Rowid物化视图

下面的语法在远程数据库表emp上创建Rowid物化视图

SQL> CREATE MATERIALIZED VIEW mv_emp_rowid

REFRESH WITH ROWID

AS SELECT * FROM emp@remote_db;

Materialized view log created

子查询物化视图

下面的语法在远程数据库表emp上创建基于emp和dept表的子查询物化视图

SQL> CREATE MATERIALIZED VIEWmv_empdept

AS SELECT * FROM emp@remote_db e

WHERE EXISTS

(SELECT * FROM dept@remote_db d

WHERE edept_no = ddept_no)

Materialized view log created

REFRESH 子句

[refresh [fast|complete|force]

[on demand | commit]

[start with date] [next date]

[with {primary key|rowid}]]

Refresh选项说明:

a noracle用刷新方法在物化视图中刷新数据

b 是基于主键还是基于rowid的物化视图

c 物化视图的刷新时间和间隔刷新时间

Refresh方法FAST子句

增量刷新用物化视图日志(参照上面所述)来发送主表已经修改的数据行到物化视图中如果指定REFRESH FAST子句那么应该对主表创建物化视图日志

SQL> CREATE MATERIALIZED VIEW LOG ON emp;

Materialized view log created

对于增量刷新选项如果在子查询中存在分析函数则物化视图不起作用

Refresh方法 COMPLETE子句

完全刷新重新生成整个视图如果请求完全刷新oracle会完成 完全刷新即使增量刷新可用

Refresh Method – FORCE 子句

当指定FORCE子句如果增量刷新可用Oracle将完成增量刷新否则将完成完全刷新如果不指定刷新方法(FAST COMPLETE or FORCE)Force选项是默认选项

主键和ROWD子句

WITH PRIMARY KEY选项生成主键物化视图也就是说物化视图是基于主表的主键而不是ROWID(对应于ROWID子句) PRIMARY KEY是默认选项为了生成PRIMARY KEY子句应该在主表上定义主键否则应该用基于ROWID的物化视图

主键物化视图允许识别物化视图主表而不影响物化视图增量刷新的可用性

Rowid物化视图只有一个单一的主表不能包括下面任何一项:

nDistinct 或者聚合函数

nGroup by子查询连接和SET操作

刷新时间

START WITH子句通知数据库完成从主表到本地表第一次复制的时间应该及时估计下一次运行的时间点 NEXT 子句说明了刷新的间隔时间

SQL> CREATE MATERIALIZED VIEW mv_emp_pk

REFRESH FAST

START WITH SYSDATE

NEXTSYSDATE +

WITH PRIMARY KEY

AS SELECT * FROM emp@remote_db;

Materialized view created

在上面的例子中物化视图数据的第一个副本在创建时生成以后每两天刷新一次

总结

物化视图提供了可伸缩的基于主键或ROWID的视图指定了刷新方法和自动刷新的时间

               

上一篇:SSH进阶(二):FTP转发

下一篇:如何连接两台Oracle服务器(服务器A、服务器B,均装有NT)?