`

转:基于远程数据库表,建立本地数据库的物化视图

阅读更多
基于远程数据库表,建立本地数据库的物化视图2008年12月28日 星期日 12:40连接远程服务器
以下是引用片段:
create database link linkfwq
   connect to fzept identified by neu
   using '(DESCRIPTION =
   (ADDRESS_LIST =
   (ADDRESS = (PROTOCOL = TCP)(HOST = 10.142.202.12)(PORT = 1521))
   )
   (CONNECT_DATA =
   (SERVICE_NAME = fjept)
   )
   )';
  host=数据库的ip地址,service_name=数据库的ssid。
  其实两种方法配置dblink是差不多的,我个人感觉还是第二种方法比较好,这样不受本地服务的影响。
  数据库连接字符串可以用NET8 EASY CONFIG或者直接修改TNSNAMES.ORA里定义.
  数据库参数global_name=true时要求数据库链接名称跟远端数据库名称一样
  数据库全局名称可以用以下命令查出
  SELECT * FROM GLOBAL_NAME;
  查询远端数据库里的表
  SELECT …… FROM 表名@数据库链接名;
  查询、删除和插入数据和操作本地的数据库是一样的,只不过表名需要写成“表名@dblink服务器”而已。
  附带说下同义词创建:
  CREATE SYNONYM同义词名FOR 表名;
  CREATE SYNONYM同义词名FOR 表名@数据库链接名;
  删除dblink:DROP PUBLIC DATABASE LINK linkfwq。
  如果创建全局dblink,必须使用systm或sys用户,在database前加public。

-物化视图 简单创建
  --0.cmd 修改系统参数,在init.ora里面修改则每次都有效
  alter system set job_queue_processes=20;
  如果这个参数为0,物化视图是不会刷新的
  --1.建表,必须有索引
  create table stu
  (
  id varchar2(10) primary key,// 如果设置primary key,那就等于是创建索引,不是主键就需要建索引CREATE INDEX INDEX_STU ON STU(ID)
  name varchar2(20)
  )
  --2.建日志
  CREATE MATERIALIZED VIEW LOG ON STU;   //stu是一本地表,如果是远程服务器实例中的表就得使用远程访问符@   stu@link 上面已经介绍了@link的 意思了
    或
    CREATE MATERIALIZED VIEW LOG ON @conn_remote_orcl9i_link
  --3.建视图
  create MATERIALIZED VIEW STU_VIEW
  REFRESH FAST
  START WITH SYSDATE       //这儿设置刷新开始 点:sysdate  
  NEXT SYSDATE + 1/1440     //到刷新
  WITH PRIMARY KEY
  AS
  SELECT * FROM STU
  --4.插入数据
  INSERT INTO STU(ID,NAME) VALUES('56','555555555555');
  COMMIT;
  --5.查看视图数据变化
  SELECT * FROM oemcyd.STU_VIEW;   //oemcyd为用户

  --6.查询物化视图刷新时间
  SELECT MM.mview_name,MM.last_refresh_date FROM DBA_MVIEWS MM


详细描述物化视图创建及其option的含义
Oracle中的物化视图
       物化视图是包括一个查询结果的数据库对像,它是远程数据的的本地副本,或者用来生成基于数据表求和的汇总表。物化视图存储基于远程表的数据,也可以称为快照。
       物化视图可以查询表,视图和其它的物化视图
       通常情况下,物化视图被称为主表(在复制期间)或明细表(在数据仓库中)。
       对于复制,物化视图允许你在本地维护远程数据的副本,这些副本是只读的。如果你想修改本地副本,必须用高级复制的功能。当你想从一个表或视图中抽取数据时,你可以用从物化视图中抽取。
       对于数据仓库,创建的物化视图通常情况下是聚合视图,单一表聚合视图和连接视图。
本篇我们将会看到怎样创建物化视图并且讨论它的刷新选项。
       在复制环境下,创建的物化视图通常情况下主键,rowid,和子查询视图。
1.主键物化视图:
              下面的语法在远程数据库表emp上创建主键物化视图
        SQL> CREATE MATERIALIZED VIEW mv_emp_pk
             REFRESH FAST START WITH SYSDATE
            NEXT SYSDATE + 1/48
            WITH PRIMARY KEY
            AS SELECT * FROM emp@remote_db;
         注意:当用FAST选项创建物化视图,必须创建基于主表的视图日志,如下:
            SQL> CREATE MATERIALIZED VIEW LOG ON emp;
2.Rowid物化视图
      下面的语法在远程数据库表emp上创建Rowid物化视图
      SQL> CREATE MATERIALIZED VIEW mv_emp_rowid
            REFRESH WITH ROWID
             AS SELECT * FROM emp@remote_db; .
3.子查询物化视图
       下面的语法在远程数据库表emp上创建基于emp和dept表的子查询物化视图
            SQL> CREATE MATERIALIZED VIEW mv_empdept
            AS SELECT * FROM emp@remote_db e
            WHERE EXISTS
             (SELECT * FROM dept@remote_db d
            WHERE e.dept_no = d.dept_no)
REFRESH 子句
            [refresh [fast|complete|force]
            [on demand|commit]
            [start with date] [next date]
            [with {primary key|rowid}]]
        Refresh选项说明:
a.      oracle用刷新方法在物化视图中刷新数据.
b.      是基于主键还是基于rowid的物化视图
c.       物化视图的刷新时间和间隔刷新时间
Refresh方法-FAST子句
       增量刷新用物化视图日志(参照上面所述)来发送主表已经修改的数据行到物化视图中.如果指定REFRESH FAST子句,那么应该对主表创建物化视图日志
       SQL> CREATE MATERIALIZED VIEW LOG ON emp;.
       对于增量刷新选项,如果在子查询中存在分析函数,则物化视图不起作用。
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物化视图只有一个单一的主表,不能包括下面任何一项:
n         Distinct 或者聚合函数.
n         Group by,子查询,连接和SET操作
刷新时间
       START WITH子句通知数据库完成从主表到本地表第一次复制的时间,应该及时估计下一次运行的时间点, NEXT 子句说明了刷新的间隔时间.
            SQL> CREATE MATERIALIZED VIEW mv_emp_pk
                     REFRESH FAST
                  START WITH SYSDATE
                  NEXT SYSDATE + 2
                  WITH PRIMARY KEY
                  AS SELECT * FROM emp@remote_db;
在上面的例子中,物化视图数据的第一个副本在创建时生成,以后每两天刷新一次.
总结
物化视图提供了可伸缩的基于主键或ROWID的视图,指定了刷新方法和自动刷新的时间。
最常用到的是fresh fast 但是必须建立基于远程实例的主表或是本地实例的主表的日志   ,否则不能把主表的数据刷新到视图中

分享到:
评论

相关推荐

    SQL 优化之 oracle物化视图

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

    oracle database 10g 完整参考手册part1

    第24章 使用物化视图 第25章 使用Oracle Text进行文本搜索 第26章 使用外部表 第27章 使用回闪查询 第28章 回闪:表和数据库 第Ⅳ部分 Pl/SQL 第29章 PL/SQL简介 第30章 触发器 第31章 过程、函数与程序包 第32章 ...

    oracle materialized view

    物化视图是包括一个查询结果的数据库对像,它是远程数据的的本地副本,或者用来生成基于数据表求和的汇总表。物化视图存储基于远程表的数据,也可以称为快照(声名:本人刚刚学习物化视图这篇文章来自网络感觉有借鉴...

    oracle database 11g 高清完整中文版part2

     第26章 使用物化视图  第27章 使用oracle text 进行文本搜索  第28章 使用外部表  第29章 使用闪回查询  第30章 闪回:表和数据库  第31章 sql 重放 第ⅳ部分 pl/sql  第32章 pl/sql 简介  第33章 应用程序...

    oracle database 11g 完整参考手册中文高清完整版part3

     第26章 使用物化视图  第27章 使用oracle text 进行文本搜索  第28章 使用外部表  第29章 使用闪回查询  第30章 闪回:表和数据库  第31章 sql 重放 第ⅳ部分 pl/sql  第32章 pl/sql 简介  第33章 应用程序...

    oracle database 11g完全参考手册 高清完整版part1 共3部分

     第26章 使用物化视图  第27章 使用oracle text 进行文本搜索  第28章 使用外部表  第29章 使用闪回查询  第30章 闪回:表和数据库  第31章 sql 重放 第ⅳ部分 pl/sql  第32章 pl/sql 简介  第33章 应用程序...

    oracle远程数据同步

    该方案是测试成功的,源数据库是oracle10.2.0.3.0,目标数据库是oracle10.2.0.3.0,使用dblink和触发器和物化视图进行数据的同步,并且做到了数据的实时更新。

    Oracle_Database_11g完全参考手册.part3/3

    第26章 使用物化视图 第27章 使用Oracle Text进行文本搜索 第28章 使用外部表 第29章 使用闪回查询 第30章 闪问:表和数据 第31章 SQL重放 第Ⅳ部分 PL/SQL 第32章 PL/SQL简介 第33章 应用程序在线升级 第34章 ...

    Oracle_Database_11g完全参考手册.part2/3

    第26章 使用物化视图 第27章 使用Oracle Text进行文本搜索 第28章 使用外部表 第29章 使用闪回查询 第30章 闪问:表和数据 第31章 SQL重放 第Ⅳ部分 PL/SQL 第32章 PL/SQL简介 第33章 应用程序在线升级 第34章 ...

    毕业设计网站开发源码-Data-Warehouse-SQL-Queries-Optimizer:数据仓库星型联接查询网站优化器(成本降低器),

    创建的优化器是一个具有远程数据库连接的网站,它允许使用一种技术来降低这些查询的成本:物化视图。 基本信息 项目于2018 年发布,作为许可证学位的毕业项目,领域:信息系统工程与软件。 目标是设计一个在线模拟器...

Global site tag (gtag.js) - Google Analytics