oracle 知识点实记

1.0
dbms_output.put_line();设置环境set   serveroutput   on   size   100000
dbms_output.put后必须再调用dbms_output.put_line才能将结果显示,因为put是没有输出回

车,也就是说这一行还没结束,所以看不见。
===================================================================================

2.0
TRANSLATE(field,  '0123456789 ',  ' ')
把field字段中的字母转为' ',数字不变!! 
===================================================================================

3.0
partition p3 values(default)
or
partition p3 values less than (MAXVALUE)
不必为最后一个分区指定最大值,MAXVALUE关键字会告诉oracle使用这个分区(p3)来存储在前面

几个分区中不能存储的数据
===================================================================================
4.0

使用LAG和LEAD函数统计
Lag和Lead函数可以在一次查询中取出同一字段的前N行的数据和后N行的值。这种操作可以使用

对相同表的表连接来实现,不过使用LAG和LEAD有更高的效率。以下是LAG和LEAD的例子:

SQL> select  year,region,profit ,lag (profit,1) over  (order by year)

 

  2       as last_year_exp from test;

 

YEAR REGION      PROFIT LAST_YEAR_EXP

---- ------- ---------- -------------

2003 West            88

2003 West            88            88

2003 Central        101            88

2003 Central        100           101

2003 East           102           100

2004 West            77           102

2004 East           103            77

2004 West            89           103

 

SQL> select  year,region,profit ,lead (profit,1) over  (order by year)

 

  2       as next_year_exp from test;

 

YEAR REGION      PROFIT NEXT_YEAR_EXP

---- ------- ---------- -------------

2003 West            88            88

2003 West            88           101

2003 Central        101           100

2003 Central        100           102

2003 East           102            77

2004 West            77           103

2004 East           103            89

2004 West            89

Lag函数为Lag(exp,N,defval),defval是当该函数无值可用的情况下返回的值。Lead函数的用

法类似。

Lead和Lag函数也可以使用分组,以下是使用region分组的例子:

SQL> select  year,region,profit ,

  2  lag (profit,1,0) over  (PARTITION BY region order by year)

 

  3       as last_year_exp from test;

 

YEAR REGION      PROFIT LAST_YEAR_EXP

---- ------- ---------- -------------

2003 Central        101             0

2003 Central        100           101

2003 East           102             0

2004 East           103           102

2003 West            88             0

2003 West            88            88

2004 West            77            88

2004 West            89            77

===================================================================================
 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值