Chinaunix首页 | 论坛 | 博客
  • 博客访问: 632639
  • 博文数量: 825
  • 博客积分: 5000
  • 博客等级: 大校
  • 技术积分: 4980
  • 用 户 组: 普通用户
  • 注册时间: 2008-10-27 14:19
文章分类

全部博文(825)

文章存档

2011年(1)

2008年(824)

我的朋友

分类:

2008-10-27 14:27:37

  从AskTom的文章里看到一段关於mv (materialize view)的操作过程,随手就把他纪录了下来,提供参考。

> create table t ( x int primary key, y int);

Table created.

>
> create materialized view t_mv
2 refresh on commit
3 as
4 select y, count(*) cnt from t
5 group by y;

Materialized view created.

>
> create or replace trigger t_mv_trigger
2 after insert or update or delete
3 on t_mv
4 begin
5 if ( inserting )
6 then
7 dbms_output.put_line( 'Hey, I fired!! for insert' );
8 end if;
9 if ( deleting )
10 then
11 dbms_output.put_line( 'Hey, I fired!! for deleting' );
12 end if;
13 if ( updating )
14 then
15 dbms_output.put_line( 'Hey, I fired!! for updating' );
16 end if;
17 end;
18 /

Trigger created.

>
> insert into t values ( 1, 1 );

1 row created.

> exec null;

PL/SQL procedure successfully completed.

>
> commit;

Commit complete.

> exec null;
Hey, I fired!! for deleting
Hey, I fired!! for insert

PL/SQL procedure successfully completed.

  上面的lab给了我几个新的学习

  第一:mv每当更新资料的程序并非update mv,而是先delete再insert新资料,我想的是那当这个mv是非常庞大的时候,即时的refresh不就非常吃resource?

  第二:exec null可以直接取出 DBMS_OUTPUT buffer的资讯。

【责编:Amy】

--------------------next---------------------

阅读(426) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~