楼主: jiangyt

[精华] sql求解

[复制链接]
论坛徽章:
0
21#
发表于 2005-1-18 15:49 | 只看该作者
可以这样实现:
SELECT distinct a1,first_value(a3) over (partition by a1 order BY l DESC)
  from (
        SELECT a1,a2,LEVEL l,replace(sys_connect_by_path(a2,';'),';') a3
        FROM (SELECT a1||ROWNUM c,a1||ROWNUM-1 p,a1,a2 FROM a)
        CONNECT BY PRIOR c = p )

使用道具 举报

回复
论坛徽章:
1
祖国60周年纪念徽章
日期:2009-10-09 08:28:00
22#
发表于 2005-2-25 17:35 | 只看该作者
zbjiao的方法在9I上适用
你好历害啊

使用道具 举报

回复
论坛徽章:
226
BLOG每日发帖之星
日期:2010-02-11 01:01:06紫蛋头
日期:2013-01-12 23:45:222013年新春福章
日期:2013-02-25 14:51:24问答徽章
日期:2013-10-17 18:06:40优秀写手
日期:2013-12-18 09:29:10马上有车
日期:2014-02-19 11:55:14马上有房
日期:2014-02-19 11:55:14马上有钱
日期:2014-02-19 11:55:14马上有对象
日期:2014-02-19 11:55:14马上加薪
日期:2014-02-19 11:55:14
23#
发表于 2005-2-26 01:22 | 只看该作者
自己写个聚集函数就可以了,例子看这里:
http://blog.itpub.net/post/468/3380

使用道具 举报

回复
论坛徽章:
7
数据库板块每日发贴之星
日期:2005-03-27 01:01:21数据库板块每日发贴之星
日期:2005-05-08 01:01:23授权会员
日期:2005-11-05 17:10:38会员2006贡献徽章
日期:2006-04-17 13:46:34ITPUB新首页上线纪念徽章
日期:2007-10-20 08:38:44喜羊羊
日期:2015-03-04 14:49:392015年新春福章
日期:2015-03-06 11:57:31
24#
发表于 2005-2-26 23:33 | 只看该作者
这个问题TOM早就研究过了。结论是sys_connect_by_path不实用, 最好是自己写个Aggregate Function.

纯粹从作游戏的角度来说,还可以把所有字符转成ASCII吗,按位排好.SUM后再转回来。

下面是个 Proof of concept  的例子,千万可不要当真

select * from test;

   C1 C2
----- -------------
    1 a
    1 b
    1 c
    2 aa
    2 bb

select c1, replace(replace(replace(str, '011', 'a'), '022', 'b'), '033', 'c')
from (
select c1, lpad(sum(power(power(10, l*3), x-1)*xc), sum(l)*3,'0') str from
(select c1, row_number() over (partition by c1 order by c2 desc) x, length(c2) l,
replace(replace(replace(c2, 'a', '011'), 'b', '022'), 'c', '033') xc from test)
group by c1
)

1 abc
2 aabb

使用道具 举报

回复
论坛徽章:
0
25#
发表于 2005-5-12 21:07 | 只看该作者
用oracle的自定义聚合函数

使用道具 举报

回复
论坛徽章:
5
ITPUB新首页上线纪念徽章
日期:2007-10-20 08:38:44
26#
发表于 2005-5-12 22:31 | 只看该作者
厉害

使用道具 举报

回复
论坛徽章:
1
2013年新春福章
日期:2013-02-25 14:51:24
27#
发表于 2005-7-8 15:29 | 只看该作者
众多高手齐出山了啊,瞻仰

使用道具 举报

回复
论坛徽章:
94
会员2007贡献徽章
日期:2007-09-26 18:42:102013年新春福章
日期:2013-02-25 14:51:24鲜花蛋
日期:2013-01-17 10:14:19ITPUB 11周年纪念徽章
日期:2012-10-09 18:06:20蛋疼蛋
日期:2011-11-09 14:19:52蛋疼蛋
日期:2011-08-11 09:31:52蛋疼蛋
日期:2011-08-08 11:05:52双黄蛋
日期:2011-07-06 15:15:11蛋疼蛋
日期:2011-06-29 13:02:442010广州亚运会纪念徽章:帆船
日期:2011-03-29 14:26:18
28#
发表于 2005-9-29 17:24 | 只看该作者
如果ORACLE里有个分析函数是使同一分区下的行获取统一的ID号,那该多好!
再配合DECODE简直是完美!

使用道具 举报

回复
论坛徽章:
3
数据库板块每日发贴之星
日期:2006-02-18 01:02:33会员2007贡献徽章
日期:2007-09-26 18:42:10ITPUB新首页上线纪念徽章
日期:2007-10-20 08:38:44
29#
发表于 2005-12-22 21:44 | 只看该作者

SYS_CONNECT_BY_PATH

SQL> create table t(col1 varchar2(10),col2 varchar2(10));

表已创建。

SQL>
SQL> insert into t values('001','vl1');

已创建 1 行。

SQL> insert into t values('001','vl2');

已创建 1 行。

SQL> insert into t values('001','vl3');

已创建 1 行。

SQL> insert into t values('002','vl1');

已创建 1 行。

SQL> insert into t values('002','vl2');

已创建 1 行。

SQL> insert into t values('002','vl3');

已创建 1 行。

SQL> insert into t values('002','vl4');

已创建 1 行。

SQL> COMMIT;

提交完成。

SQL> select * from t;

COL1       COL2
---------- ----------
001        vl1
001        vl2
001        vl3
002        vl1
002        vl2
002        vl3
002        vl4

已选择7行。

SQL> COL COL2 FORMAT A20

SQL>  SELECT COL1,LTRIM(MAX(SYS_CONNECT_BY_PATH(COL2,',')),',') COL2
  2   FROM
  3   (
  4   SELECT COL1,COL2,MIN(COL2) OVER(PARTITION BY COL1) COL2_MIN,
  5  (ROW_NUMBER() OVER(ORDER BY COL1,COL2))+(DENSE_RANK() OVER (ORDER BY COL1)) NUMID
  6   FROM T
  7   )
  8   START WITH COL2=COL2_MIN CONNECT BY NUMID-1=PRIOR NUMID
  9   GROUP BY COL1;

COL1       COL2
---------- --------------------
001        vl1,vl2,vl3
002        vl1,vl2,vl3,vl4

我个人觉得这个就好用了

使用道具 举报

回复
论坛徽章:
484
ITPUB北京香山2007年会纪念徽章
日期:2007-01-24 14:35:02ITPUB北京九华山庄2008年会纪念徽章
日期:2008-01-21 16:50:24ITPUB北京2009年会纪念徽章
日期:2009-02-09 11:42:452010新春纪念徽章
日期:2010-03-01 11:04:552010数据库技术大会纪念徽章
日期:2010-05-13 10:04:272010系统架构师大会纪念
日期:2010-09-04 13:35:54ITPUB9周年纪念徽章
日期:2010-10-08 09:28:512011新春纪念徽章
日期:2011-02-18 11:43:32ITPUB十周年纪念徽章
日期:2011-11-01 16:19:412012新春纪念徽章
日期:2012-01-04 11:49:54
30#
发表于 2005-12-24 00:51 | 只看该作者
SYS_CONNECT_BY_PATH是好用
不过8i下不能用
还有前面biti_rainy提到的,楼上应去看看

使用道具 举报

回复

您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

TOP技术积分榜 社区积分榜 徽章 团队 统计 知识索引树 积分竞拍 文本模式 帮助
  ITPUB首页 | ITPUB论坛 | 数据库技术 | 企业信息化 | 开发技术 | 微软技术 | 软件工程与项目管理 | IBM技术园地 | 行业纵向讨论 | IT招聘 | IT文档
  ChinaUnix | ChinaUnix博客 | ChinaUnix论坛
CopyRight 1999-2011 itpub.net All Right Reserved. 北京盛拓优讯信息技术有限公司版权所有 联系我们 未成年人举报专区 
京ICP备16024965号-8  北京市公安局海淀分局网监中心备案编号:11010802021510 广播电视节目制作经营许可证:编号(京)字第1149号
  
快速回复 返回顶部 返回列表