首页
论坛
门户
空间
手机版
IXPUB
插件
收藏
设置
注册
登录
商店
搜索
培训
Wiki
Blog
归档
丛书
退出
ITPUB论坛
»
Oracle开发
» 请教一sql
‹‹ 上一主题
|
下一主题 ››
11
1/2
1
2
››
投票
交易
悬赏
活动
评价
|
打印
|
推荐
|
订阅
|
收藏
标题:
[SQL]
请教一sql
yyy16xx
mikk
来自 乌鲁木齐
精华贴数 0
个人空间
0
技术积分 137 (13201)
社区积分 7 (13756)
注册日期 2008-4-2
论坛徽章:1
#1
使用道具
发表于 2008-9-17 11:15
请教一sql
环境 xp+9i
有一个销售表(业务员,产品,销售额)
003 c 86
002 c 76
004 c 67
005 c 76
006 c 55
001 d 95
002 d 88
004 d 82
003 d 99
要得到按产品分组得到销售额前三名的业务员如
产品 第一 第二 第三
c 003 86 002 76,005 76 004 67
这个第二 有2个(也有可能是多个)
这个sql怎么写
__________________
昨天,今天,明天!
只看该作者
过过招
坚挺旗舰
Guiding Star
精华贴数 0
个人空间
0
技术积分 975 (1943)
社区积分 27 (6734)
注册日期 2005-6-10
论坛徽章:0
#2
使用道具
发表于 2008-9-17 11:20
呵呵,又是一个行列转换。
每个产品对应的记录是不是不定?如果不定,必须用PL/SQL动态SQL拼凑~
__________________
只看该作者
cosio
资深会员
精华贴数 0
个人空间
0
技术积分 1642 (1046)
社区积分 46 (5205)
注册日期 2004-8-8
论坛徽章:2
#3
使用道具
发表于 2008-9-17 11:23
动态的SQL,网上很多,可以找一下!
在不行到我的博客中找一下!
__________________
QQ:75558288
__________________
MSN:fenny_8@hotmail.com
__________________
Web:http://cosio.itpub.net
只看该作者
lemonlau
学好oracle
来自 湖北---广东
精华贴数 1
个人空间
0
技术积分 673 (2890)
社区积分 14 (9370)
注册日期 2008-1-11
论坛徽章:1
#4
使用道具
发表于 2008-9-17 11:39
他的销售额肯定是个变量的 。。。
这样只能用动态sql去写。。
__________________
两年前有人问我erp是什么?我傻了。又问我sql是什么,我还是傻了。两年后我终于踏上了这条道路。
希望pub的朋友多多指教
只看该作者
grubbyoo
▃▃,~
来自 夕阳小画
精华贴数 1
个人空间
6
技术积分 1682 (1035)
社区积分 349 (1789)
注册日期 2007-3-1
论坛徽章:15
#5
使用道具
发表于 2008-9-17 11:58
create table test(seller varchar2(5),product varchar2(5),amt number)
insert into test values (003,'c',86);
insert into test values (002,'c',76);
insert into test values (004,'c',67);
insert into test values (005,'c',76);
insert into test values (006,'c',55);
insert into test values (001,'d',95);
insert into test values (002,'d',88);
insert into test values (004,'d',82);
insert into test values (003,'d',99);
select product ,max(substr(sys_connect_by_path(seller||':'||amt,','),2)) keep (dense_rank last order by decode(rn,1,level,-1)) first,
max(substr(sys_connect_by_path(seller||':'||amt,','),2)) keep (dense_rank last order by decode(rn,2,level,-1)) sec,
max(substr(sys_connect_by_path(seller||':'||amt,','),2)) keep (dense_rank last order by decode(rn,3,level,-1)) third
from
(select a.*,dense_rank() over (partition by product order by amt desc ) rn,
row_Number() over (partition by product order by amt desc ) num
from test a ) a
connect by product=prior product
and rn= prior rn
and num=prior num+1
group by product
product first sec third
c 3:86 2:76,5:76 4:67
d 3:99 1:95 2:88
__________________
走到哪里才不是过客
只看该作者
ysl_1981
南方小狼
精华贴数 0
个人空间
0
技术积分 84 (19646)
社区积分 1 (43275)
注册日期 2006-11-20
论坛徽章:0
#6
使用道具
发表于 2008-9-17 12:04
Select 产品 ,decode(dn,1,业务员|| 销售额 )as 第一, 第二||decode(dn,2,业务员|| 销售额 )as 第二, decode(dn,3,业务员|| 销售额 )as 第三
From(Select 产品 ,业务员,销售额, dense_rank( ) over (prarttion by 业务员 order by 销售额 ) as rn
From 销售表);
只看该作者
yyy16xx
mikk
来自 乌鲁木齐
精华贴数 0
个人空间
0
技术积分 137 (13201)
社区积分 7 (13756)
注册日期 2008-4-2
论坛徽章:1
#7
使用道具
发表于 2008-9-17 13:04
十分感谢大家!默拜grubbyoo中.........
__________________
昨天,今天,明天!
只看该作者
lazyman2008
精华贴数 0
个人空间
0
技术积分 466 (4238)
社区积分 7 (13719)
注册日期 2007-11-19
论坛徽章:1
#8
使用道具
发表于 2008-9-17 13:33
grubbyoo!牛!
只看该作者
limangdu
初级会员
精华贴数 0
个人空间
0
技术积分 224 (8686)
社区积分 0 (1509279)
注册日期 2007-8-10
论坛徽章:0
#9
使用道具
发表于 2008-9-17 16:43
QUOTE:
原帖由
grubbyoo
于 2008-9-17 11:58 发表
create table test(seller varchar2(5),product varchar2(5),amt number)
insert into test values (003,'c',86);
insert into test values (002,'c',76);
insert into test values (004,'c',67);
insert into test values (005,'c',76);
insert into test values (006,'c',55);
insert into test values (001,'d',95);
insert into test values (002,'d',88);
insert into test values (004,'d',82);
insert into test values (003,'d',99);
select product ,max(substr(sys_connect_by_path(seller||':'||amt,','),2)) keep (dense_rank last order by decode(rn,1,level,-1)) first,
max(substr(sys_connect_by_path(seller||':'||amt,','),2)) keep (dense_rank last order by decode(rn,2,level,-1)) sec,
max(substr(sys_connect_by_path(seller||':'||amt,','),2)) keep (dense_rank last order by decode(rn,3,level,-1)) third
from
(select a.*,dense_rank() over (partition by product order by amt desc ) rn,
row_Number() over (partition by product order by amt desc ) num
from test a ) a
connect by product=prior product
and rn= prior rn
and num=prior num+1
group by product
product first sec third
c 3:86 2:76,5:76 4:67
d 3:99 1:95 2:88
高手!
只看该作者
newkid
资深新手
老程序员
来自 银河系
精华贴数 2
个人空间
0
技术积分 2756 (579)
社区积分 0 (121048)
注册日期 2004-6-26
论坛徽章:5
#10
使用道具
发表于 2008-9-18 00:32
SELECT product
,MAX(DECODE(rn,1,performance))
,MAX(DECODE(rn,2,performance))
,MAX(DECODE(rn,3,performance))
FROM (SELECT product
,rn
,wmsys.wm_concat(seller||':'||amt) AS performance
FROM (SELECT a.*
,dense_rank() over (partition by product order by amt desc ) rn
FROM test a
) a
WHERE rn<=3
GROUP BY product
,rn
)
GROUP BY product;
grubbyoo用connect by简直是炉火纯青了,不过我还是要建议你加上 start with rn<=3 connect by product=prior product and rn<=3 减少不必要的运算!
__________________
只看该作者
11
1/2
1
2
››
投票
交易
悬赏
活动
相关内容
ITPUB论坛
≡ 数据库技术 ≡
> Oracle数据库管理
> Oracle开发
> Oracle Developer Suite
> Oracle入门与认证
> Oracle专题深入讨论
> Oracle新技术/11g
> Oracle电子文档
> Oracle Fusion中间件
> IBM数据库产品
> MS SQL Server
> Sybase管理与开发
> MySQL及其它开源数据库
> 内存数据库
> 数据仓库与数据挖掘
> 移动及嵌入式数据库
≡ 企业信息化 ≡
> ERP产品与实践
> CRM产品与实践
> HR产品与实践
> 物流
> 供应链
> 供应链建模与仿真
> 物流设备与系统工程
> 企业管理咨询
> 管理协同与办公自动化
> IT服务管理
> 数据中心建设
> ERP二次开发
> Oracle ERP
> Oracle EBS R12
> PeopleSoft与JDE
> EBS相关文档
> SAP R/3
> SAP Business One开发与快速实施
> SAP财务及CRM
> SAP后勤及HR
> mySAP ERP
> 系统开发及跨应用设置
> SAP相关文档
> 国外其它ERP产品
> 国内ERP产品
≡ 开发技术 ≡
> Java入门与认证版
> Java web开发及框架技术
> Java企业开发
> ASP.NET【已迁移到微软开发技术论坛】
> .Net企业开发与应用【已迁移到微软开发技术论坛】
> WEB程序开发
> WEB 2.0技术
> 动态语言
> 移动与游戏开发
≡ 系统设计与项目管理 ≡
> 系统分析与UML
> 系统分析与UML精华区
> 项目管理
> 项目过程
> 软件测试
> 算法讨论与研究
≡ IBM软件技术园地 ≡
> IBM数据库产品
> Lotus
> Tivoli
> Websphere
> Rational
> 与SOA相关的IBM产品与技术
> IBM软件技术精英协会
> 软件技术精英活动专版
≡ 操作系统与硬件 ≡
> AIX及IBM产品【已迁移到IXPUB】
> HP-UX及HP产品【已迁移到IXPUB】
> Solaris及SUN产品【已迁移到IXPUB】
> Linux及其应用 【已迁移到IXPUB】
> 其它UNIX系统【已迁移到IXPUB】
> windows系统及微软相关产品 【已迁移到IXPUB】
> 存储设备与容灾技术 【已迁移到IXPUB】
> 服务器 【已迁移到IXPUB】
≡ 行业纵向讨论区 ≡
> IT业界评论与展望
> 政府与教育事业
> 中国政府信息主管联盟
> 电信行业
> 金融行业
> 医卫行业
> 制造行业
> 电力行业
> 信息安全与审计
≡ 会员交流 ≡
> IT职业生涯
> 招聘求职商务信息
> 体育世界
> 体育博彩专版
> 旅游,驴友
> 汽车世界
> 外语角
> 数码摄影
> 你的故事我的歌
> 音乐推荐区
> 电子图书与IT文档资料
> 软件交流
> 软件交流精华区
≡ ITPUB产品与服务 ≡
> ITPUB地面活动专版
> BLOG天地
> WIKI世界
> 授权用户区
> 站务管理
≡ 微软开发技术 ≡
> 开发工具和语言
> .NET Framework 相关
> Visual Basic/VB.net
> Visual C#
> Visual C++/vc.net
> Visual Studio
> .NET软件架构与模式
> .NET开发辅助工具及框架
> Web开发
> ASP.NET与AJAX
> Web相关技术讨论(IIS等)
> Silverlight 技术
> 微软企业级产品技术
> SQL Server
> windows server
> SharePoint
> Exchange Server
> Biztalk
> 嵌入式及移动开发
> Windows Embedded 嵌入式技术
> Windows 移动设备
> Office开发
> Microsoft office system
> Office Business Application
> 微软产品用户交流区
> .Net电子书籍&&书籍介绍
> .Net人才交流
技术积分榜
社区积分榜
徽章
电子杂志
会员
团队
统计
邮箱
游乐场
帮助
TOP
CopyRight 1999-2006 itpub.net All Right Reserved.
北京皓辰广域网络信息技术有限公司. 版权所有
E-mail:Webmaster@itpub.net
京ICP证:010037号
联系我们
法律顾问
控制面板首页
编辑个人资料
积分交易
公众用户组
好友列表
升级个人空间
基本概况
论坛排行
主题排行
发帖排行
积分排行
在线时间
管理团队
管理统计