• ORACLE 物化视图


    最近几天,我负责的P项目环境中提供给W系统的一个视图,由于查询逻辑复杂,数据量比较大,导致每次查询视图的时候,查询速度慢,效率低下,遭到了w系统人员的投诉。想了想,还是改成物化视图吧,用了物化视图,腰不酸,腿不痛,查询快了,投诉少了,谁用谁知道,呵呵。

    真要详细陈述物化视图的相关内容,篇幅过大,所以此处仅记录了我自己在这次调整中所做的操作。创建最简单的物化视图,不使用快速刷新,所以此处不创建物化视图日志。

    创建物化视图语句如下(因为数据问题,此处更改了查询内容):

    CREATE MATERIALIZED VIEW MV_TableName
            BUILD IMMEDIATE      --创建时立即刷新
             REFRESH FORCE        --如果可以快速刷新则进行快速刷新,否则完全刷新
             ON DEMAND            --刷新方式
             START WITH SYSDATE   --第一次刷新时间
             NEXT  SYSDATE+1/12   --刷新时间间隔
             AS SELECT 1 id ‘A’ name FROM dual;

    我自己在PLSQL中执行的时候,有时会因为注释的原因,导致物化视图创建失败,所以,创建时还是删去注释吧。

    如果某些情况想要修改刷新频率,可以使用以下命令修改刷新间隔

    ALTER MATERIALIZED VIEW MV_TableName
           REFRESH FORCE 
           ON DEMAND 
           START WITH SYSDATE 
           NEXT SYSDATE+1/144;

    查询物化视图上次刷新时间

    SELECT last_refresh_date 
         FROM user_mviews 
        WHERE mview_name = 'MV_TABLENAME';

    手动刷新物化视图

    BEGIN
           dbms_mview.refresh('MV_TABLENAME');
        END;

    删除物化视图的话,可以使用如下语句

    DROP MATERIALIZED VIEW MV_TableName;
  • 相关阅读:
    k8s环境实现springcloud电商项目(二)SpringCloud及组件介绍&Eureka组件部署
    k8s核心资源之service四层负载均衡器代理(六)
    在B串中查找是否有A串华为
    matplotlib学习笔记
    Spring IOC 常用注解与使用
    Spring AOP快速使用教程
    SpringBoot启动原理
    BeanFactory和ApplicationContext的区别总结
    泛型之泛型方法
    Lombok中的@Builder注解的使用
  • 原文地址:https://www.cnblogs.com/jsllgjk/p/3837450.html
Copyright © 2020-2023  润新知