首页 > 代码库 > ORACLE 物化视图
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;
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。