linux max 函数,【Analytic】分析函数之MAX函数

MAX函数与MIN函数的使用方法相同,MIN取最小值,MAX取最大值。重点还是放在普通MAX函数与MAX分析函数的区别上。【Analytic】分析函数之MIN函数:http://space.itpub.net/519536/viewspace-6247361.万变不离其宗,先看MAX函数的语法描述。MAX([ DISTINCT | ALL ] expr)[ OVER (analytic_clause) ]2.通过实验看一下两种MAX函数的用法和区别1)创建测试表T,并初始化几条数据。sec@ora10g> create table t (group_id number(10), name varchar2(10), salary int);sec@ora10g> insert into t values (1,'Tom',1200);sec@ora10g> insert into t values (2,'Kary',2400);sec@ora10g> insert into t values (2,'Joe',800);sec@ora10g> insert into t values (3,'Erick',3600);sec@ora10g> insert into t values (3,'Andy',600);sec@ora10g> insert into t values (3,'Mary',300);sec@ora10g> commit;2)T表全貌sec@ora10g> select * from t;GROUP_ID NAME                               SALARY---------- ------------------------------ ----------1 Tom                                  12002 Kary                                 24002 Joe                                   8003 Erick                                36003 Andy                                  6003 Mary                                  3006 rows selected.共三组数据,group_id分别是1、2和3。第1组有一个人,第2组有两个人,第3组有三个人。最后一列是每个人的薪水值。3)先看一下普通MAX函数的用法sec@ora10g> select group_id, name, salary, max(salary) from t group by group_id, name, salary order by group_id;GROUP_ID NAME                               SALARY MAX(SALARY)---------- ------------------------------ ---------- -----------1 Tom                                  1200        12002 Joe                                   800         8002 Kary                                 2400        24003 Andy                                  600         6003 Erick                                3600        36003 Mary                                  300         3006 rows selected.得到的最大值是按照“group_id, name, salary”三列进行分组后的每组最大值。4)再看一下分析函数MAX得到的最大值sec@ora10g> select group_id, name, salary, max(salary) over (partition by group_id) analytic_max from t order by group_id;

GROUP_ID NAME                               SALARY ANALYTIC_MAX

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

1 Tom                                  1200         1200

2 Kary                                 2400         2400

2 Joe                                   800         2400

3 Erick                                3600         3600

3 Andy                                  600         3600

3 Mary                                  300         3600

6 rows selected.注意这里得到的最大值与基本MAX函数得到的最大值区别,这里的最大值是每行记录所对应组内的最高薪酬值。3.小结透过函数的基本功能看本质,很普通的函数同样孕育着伟大的力量。有关分析函数的扩展可以参考Oracle的官方文档中的“Analytic Functions”描述:Good luck.secooler10.01.09-- The End --

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值