首页
论坛
门户
空间
手机版
IXPUB
插件
收藏
设置
注册
登录
商店
搜索
培训
Wiki
Blog
归档
丛书
退出
ITPUB论坛
»
Oracle开发
» 求个SQL语句
‹‹ 上一主题
|
下一主题 ››
18
1/2
1
2
››
投票
交易
悬赏
活动
评价
|
打印
|
推荐
|
订阅
|
收藏
标题: 求个SQL语句
david_liao
青鳥
精华贴数 2
个人空间
0
技术积分 1697 (990)
社区积分 120 (3110)
注册日期 2005-6-6
论坛徽章:4
#1
使用道具
发表于 2006-9-28 13:59
求个SQL语句
表A
partid matid partweight
ccc cccc 1
bbb bbbb 2
ddd dddd 3
eee eeee 4
fff ffff 5
请问用什么语句可实现从表A到下面格式的显示,谢谢......
partid matid partweight test
ccc cccc 1 1/1
bbb bbbb 2 1/2
bbb bbbb 2 2/2
ddd dddd 3 3/3
ddd dddd 3 1/3
ddd dddd 3 2/3
eee eeee 4 1/4
eee eeee 4 2/4
eee eeee 4 3/4
eee eeee 4 4/4
fff ffff 5 1/5
fff ffff 5 2/5
fff ffff 5 3/5
fff ffff 5 4/5
fff ffff 5 5/5
david_liao 上传了这个附件:
2006-9-28 13:59
bbbb.gif
(6.52 KB)
__________________
臨淵羨魚,不如退而結網......禮之用,和爲貴......有志者,事競成,勵精圖治,百二秦關終屬楚。 苦心人,天不負,臥薪嘗膽,三千越甲可吞吳。香荷碧水动风凉,水动风凉夏日长,长日夏凉风动水,凉风动水碧荷香。
只看该作者
xzh2000
仙人抚我须 结发授长生
精华贴数 13
个人空间
0
技术积分 46440 (14)
社区积分 5155 (286)
注册日期 2002-7-17
论坛徽章:30
#2
使用道具
发表于 2006-9-28 14:33
14:33:29 SQL> select type,qty from test;
TYPE QTY
---------- ----------
1 3
1 6
2 5
2 9
2 7
14:33:36 SQL> select type,qty,to_char(row_number() over(partition by type order by qty))||'/'||to_char(count(*) over(partition by type)) as cnt2 from test;
TYPE QTY CNT2
---------- ---------- ------------
1 3 1/2
1 6 2/2
2 5 1/3
2 7 2/3
2 9 3/3
__________________
过目即忘 插柳成荫
只看该作者
xzh2000
仙人抚我须 结发授长生
精华贴数 13
个人空间
0
技术积分 46440 (14)
社区积分 5155 (286)
注册日期 2002-7-17
论坛徽章:30
#3
使用道具
发表于 2006-9-28 15:01
QUOTE:
最初由 xzh2000 发布
14:33:29 SQL> select type,qty from test;
TYPE QTY
---------- ----------
1 3
1 6
2 5
2 9
2 7
14:33:36 SQL> select type,qty,to_char(row_number() over(partition by type order by qty))||'/'||to_char(count(*) over(partition by type)) as cnt2 from test;
TYPE QTY CNT2
---------- ---------- ------------
1 3 1/2
1 6 2/2
2 5 1/3
2 7 2/3
2 9 3/3
没看清楚,不过这个用pl/sql应该很容易实现。。。
__________________
过目即忘 插柳成荫
只看该作者
david_liao
青鳥
精华贴数 2
个人空间
0
技术积分 1697 (990)
社区积分 120 (3110)
注册日期 2005-6-6
论坛徽章:4
#4
使用道具
发表于 2006-9-28 15:03
楼主误会了
像楼主这样是很容易实现,现在的要求是如是INT 型栏位的值是2就要产生2行,test栏位的值分别是1/2,2/2,而如果是3就要产生3行,test栏位的值分别是1/3,2/3,3/3,而如果是100,就要产生100行,test栏位的值分别是1/100,2/100......99/100,100/100,而不是有2的栏位有3行才产生1/3,2/3,3/3
__________________
臨淵羨魚,不如退而結網......禮之用,和爲貴......有志者,事競成,勵精圖治,百二秦關終屬楚。 苦心人,天不負,臥薪嘗膽,三千越甲可吞吳。香荷碧水动风凉,水动风凉夏日长,长日夏凉风动水,凉风动水碧荷香。
只看该作者
zhouwf0726
版主
精华贴数 5
个人空间
927
技术积分 7431 (172)
社区积分 108 (3309)
注册日期 2006-2-22
论坛徽章:20
#5
使用道具
发表于 2006-9-28 15:07
SQL> SELECT * FROM TEST;
PARTID MATID PARTWEIGHT
-------------------- ------------------------------------------------------------ -------------------
ccc cccc 1
bbb bbbb 2
ddd dddd 3
eee eeee 4
fff ffff 5
SQL>
SQL> SELECT PARTID,MATID,ROW_NUMBER() OVER(PARTITION BY PARTWEIGHT ORDER BY ROWNUM)||'/'||PARTWEIGHT FROM(
2 SELECT PARTID,MATID,PARTWEIGHT FROM TEST,
3 (
4 select substr(col,instr(col,',',1,rownum)+1,instr(col,',',1,rownum+1)-instr(col,',',1,rownum)-1) col from (
5 select ',1,2,2,3,3,3,4,4,4,4,5,5,5,5,5,' col from dual
6 ) connect by rownum<length(translate(col,','||col,','))
7 ) TEMP
8 WHERE TEST.PARTWEIGHT = TEMP.COL
9 )
10 ;
PARTID MATID ROW_NUMBER()OVER(PARTITIONBYPA
-------------------- ------------------------------------------------------------ --------------------------------------------------------------------------------
ccc cccc 1/1
bbb bbbb 1/2
bbb bbbb 2/2
ddd dddd 1/3
ddd dddd 2/3
ddd dddd 3/3
eee eeee 1/4
eee eeee 2/4
eee eeee 3/4
eee eeee 4/4
fff ffff 1/5
fff ffff 2/5
fff ffff 3/5
fff ffff 4/5
fff ffff 5/5
15 rows selected
__________________
msn:zhouwf0726@hotmail.commail:zhouwf0726@163.com
只看该作者
zhouwf0726
版主
精华贴数 5
个人空间
927
技术积分 7431 (172)
社区积分 108 (3309)
注册日期 2006-2-22
论坛徽章:20
#6
使用道具
发表于 2006-9-28 15:09
上边的这个按照如下规律实现:
partweight如果是n就会出现n条数据。
n支持的最大值靠维护sql中如下部分实现。
select ',1,2,2,3,3,3,4,4,4,4,5,5,5,5,5,' col from dual
__________________
msn:zhouwf0726@hotmail.commail:zhouwf0726@163.com
只看该作者
zhouwf0726
版主
精华贴数 5
个人空间
927
技术积分 7431 (172)
社区积分 108 (3309)
注册日期 2006-2-22
论坛徽章:20
#7
使用道具
发表于 2006-9-28 15:13
其中构造temp表部分
select substr(col,instr(col,',',1,rownum)+1,instr(col,',',1,rownum+1)-instr(col,',',1,rownum)-1) col from (
select ',1,2,2,3,3,3,4,4,4,4,5,5,5,5,5,' col from dual
) connect by rownum<length(translate(col,','||col,','))
可以参看以下地址:
http://www.itpub.net/showthread.php?threadid=626516
如果存在过大n值,可以考虑借助一个临时表来实现,先把n的值初始化。
__________________
msn:zhouwf0726@hotmail.commail:zhouwf0726@163.com
只看该作者
david_liao
青鳥
精华贴数 2
个人空间
0
技术积分 1697 (990)
社区积分 120 (3110)
注册日期 2005-6-6
论坛徽章:4
#8
使用道具
发表于 2006-9-28 15:13
谢谢
对我的意思就是这样,我试试
__________________
臨淵羨魚,不如退而結網......禮之用,和爲貴......有志者,事競成,勵精圖治,百二秦關終屬楚。 苦心人,天不負,臥薪嘗膽,三千越甲可吞吳。香荷碧水动风凉,水动风凉夏日长,长日夏凉风动水,凉风动水碧荷香。
只看该作者
zhouwf0726
版主
精华贴数 5
个人空间
927
技术积分 7431 (172)
社区积分 108 (3309)
注册日期 2006-2-22
论坛徽章:20
#9
使用道具
发表于 2006-9-28 15:24
SQL> SELECT PARTID,MATID,ROW_NUMBER() OVER(PARTITION BY PARTWEIGHT ORDER BY ROWNUM)||'/'||PARTWEIGHT FROM(
2 SELECT PARTID,MATID,PARTWEIGHT FROM TEST,
3 (
4 select substr(col,instr(col,',',1,rownum)+1,instr(col,',',1,rownum+1)-instr(col,',',1,rownum)-1) col from (
5 select ',1,2,2,3,3,3,4,4,4,4,5,5,5,5,5,' col from dual
6 ) connect by rownum<length(translate(col,','||col,','))
7 ) TEMP
8 WHERE TEST.PARTWEIGHT = TEMP.COL
9 )
10
order by rownum
11 ;
PARTID MATID ROW_NUMBER()OVER(PARTITIONBYPA
-------------------- ------------------------------------------------------------ --------------------------------------------------------------------------------
ccc cccc 1/1
bbb bbbb 1/2
bbb bbbb 2/2
ddd dddd 1/3
ddd dddd 2/3
ddd dddd 3/3
eee eeee 1/4
eee eeee 2/4
eee eeee 3/4
eee eeee 4/4
fff ffff 1/5
fff ffff 2/5
fff ffff 3/5
fff ffff 4/5
fff ffff 5/5
15 rows selected
给刚才的加个排序
__________________
msn:zhouwf0726@hotmail.commail:zhouwf0726@163.com
只看该作者
pitter211
一般会员
精华贴数 0
个人空间
0
技术积分 313 (6288)
社区积分 0 (624491)
注册日期 2005-9-22
论坛徽章:1
#10
使用道具
发表于 2006-9-28 15:34
好帖 一条sql 语句实现如此多的功能。增长见识。
__________________
oracle is my wife and jsp is my lover,computer for me is all .
只看该作者
18
1/2
1
2
››
投票
交易
悬赏
活动
相关内容
ITPUB论坛
≡ 数据库技术 ≡
> Oracle数据库管理
> Oracle开发
> Oracle Developer Suite
> Oracle入门与认证
> Oracle专题深入讨论
> Oracle新技术/11g
> Oracle电子文档
> Oracle Application Server套件
> IBM数据库产品
> MS SQL Server
> Sybase管理与开发
> MySQL及其它开源数据库
> 内存数据库
> 数据仓库与数据挖掘
> 移动及嵌入式数据库
≡ 企业信息化 ≡
> ERP产品与实践
> CRM产品与实践
> HR产品与实践
> 物流
> 供应链
> 供应链建模与仿真
> 物流设备与系统工程
> 企业管理咨询
> 管理协同与办公自动化
> IT服务管理
> 数据中心建设
> ERP二次开发
> Oracle ERP
> EBS相关文档
> PeopleSoft与JDE
> 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号
联系我们
法律顾问
控制面板首页
编辑个人资料
积分交易
公众用户组
好友列表
升级个人空间
基本概况
论坛排行
主题排行
发帖排行
积分排行
在线时间
管理团队
管理统计