首页
论坛
门户
空间
手机版
IXPUB
插件
收藏
设置
注册
登录
商店
搜索
培训
Wiki
Blog
归档
丛书
退出
ITPUB论坛
»
Oracle开发
» 取查询结果的前15条数据是不是可以这样写
‹‹ 上一主题
|
下一主题 ››
12
1/2
1
2
››
投票
交易
悬赏
活动
评价
|
打印
|
推荐
|
订阅
|
收藏
标题:
[SQL]
取查询结果的前15条数据是不是可以这样写
xipipku
中级会员
精华贴数 0
个人空间
0
技术积分 624 (3104)
社区积分 2 (25265)
注册日期 2004-5-11
论坛徽章:2
#1
使用道具
发表于 2008-9-24 11:37
取查询结果的前15条数据是不是可以这样写
表test有10万条数据,根据其中的col1字段排序取前面15条,col1已经建立索引
select * from test where rownum<16 order by col1 desc;
如果col1没有索引,应该这样写
select * from (select rownum r, col1 from test order by col1) t1 where t1.r<16;
不知道上面说的是否正确?
只看该作者
Laurence.li
玉玄宫
精华贴数 0
个人空间
0
技术积分 7029 (189)
社区积分 419 (1608)
注册日期 2004-8-19
论坛徽章:20
#2
使用道具
发表于 2008-9-24 11:43
不对
你都应该按照第二种写
__________________
知人者智,自知者明。胜人者有力,自胜者强。知足者富,强行者有志。不失其所者久。死而不亡者寿。
只看该作者
xilangxiangwa
中级会员
精华贴数 1
个人空间
346
技术积分 1396 (1247)
社区积分 43 (5425)
注册日期 2007-7-26
论坛徽章:8
#3
使用道具
发表于 2008-9-24 11:47
两种写法都不对,答案如下:
select * from (select col1 from test order by col1) t1 where rownum <16;
与是否建立索引无关!
[
本帖最后由 xilangxiangwa 于 2008-9-24 11:48 编辑
]
__________________
我愿意我的就是全世界的,有你分享我的快乐,我会更快乐!
个人空间最新报道(2008/11/17):
1、FORM导出到EXCEL_设置EXCEL中字体的颜色(版本二)
欢迎大家来我的个人空间做客!
http://space.itpub.net/10595277
只看该作者
dingjun123
djゆoracle
来自 china
精华贴数 3
个人空间
0
技术积分 1915 (912)
社区积分 15 (8980)
注册日期 2006-7-28
论坛徽章:2
#4
使用道具
发表于 2008-9-24 11:59
搂上的正确,rownum和order by写一起,那么是rowmun之后再order by,顺序就乱了!
__________________
软件体系架构要以数据库为中心,如oracle,可以充分利用数据库的特性,帮助解决复杂的问题。一个常用的规则是:
如果能用单条sql解决,ok
如果不能用单条sql解决,考虑使用PL/SQL
如果不能用PL/SQL解决,考虑使用java存储过程
如果不能用java解决,那么考虑使用c外部过程
如果c都解决不了,那么考虑一下放弃吧
只看该作者
kmpx
VICTORY
精华贴数 0
个人空间
0
技术积分 1078 (1713)
社区积分 1 (43006)
注册日期 2006-10-8
论坛徽章:1
#5
使用道具
发表于 2008-9-24 12:02
JZ没弄明白rownum
__________________
别揣着糊涂装明白
只看该作者
Laurence.li
玉玄宫
精华贴数 0
个人空间
0
技术积分 7029 (189)
社区积分 419 (1608)
注册日期 2004-8-19
论坛徽章:20
#6
使用道具
发表于 2008-9-24 12:05
三楼的写法比较正规
但楼主的第二种写法结果也一定是正确的,因为rownum列的结果永远是从1开始,查询对这个列的赋值应当是在order by操作之后的。
__________________
知人者智,自知者明。胜人者有力,自胜者强。知足者富,强行者有志。不失其所者久。死而不亡者寿。
只看该作者
zhangfengh
老狐狸
精华贴数 3
个人空间
0
技术积分 14590 (79)
社区积分 7160 (220)
注册日期 2002-10-12
论坛徽章:123
#7
使用道具
发表于 2008-9-24 12:10
最好用<=15,养成好习惯
__________________
=======================================
狐狸在这个世界上是凭借聪明而得到生存的,并且在这个世界上占有一席之地,学习狐狸的聪明,少走弯路。
=======================================
吸收别人的经验,使之成为自己的经验!
=======================================
只看该作者
Laurence.li
玉玄宫
精华贴数 0
个人空间
0
技术积分 7029 (189)
社区积分 419 (1608)
注册日期 2004-8-19
论坛徽章:20
#8
使用道具
发表于 2008-9-24 12:15
其实楼主是希望提高查询的效率,我提供一种方案供参考:
如果每次查询都是desc排序,就干脆建立desc索引:
create index idx1 on test(col1 desc);
analyze table test estimate statistics for table for all indexes for all indexed columns;
select /*+ index(test idx1) */ col1 from test where rownum < 16;
这样查询出来就是降序排列的前15条了。
如果有时查降序,有时又查升序,那还是建立普通索引:
create index idx2 on test(col1);
analyze ......
查asc前15条:
select /*+ index(test idx2) */ col1 from test where rownum < 16;
查desc前15条:
select /*+ index_desc(test idx2) */ col1 from test where rownum < 16;
以上方法供参考,楼主还须多测试,把数据打乱测试一下,确保正确性后,检验效率,目的其实就是希望不再访问表,而仅仅通过索引取出前15条,当然,你这个col1字段应该是not null的,否则你最好在查询里加上where col1 is not null的查询条件
还有就是,sql的执行和oracle的版本也是有关系的,以上方法曾在9i里用过,问题应该不大,更早的版本就不得而知了,呵呵
__________________
知人者智,自知者明。胜人者有力,自胜者强。知足者富,强行者有志。不失其所者久。死而不亡者寿。
只看该作者
kmpx
VICTORY
精华贴数 0
个人空间
0
技术积分 1078 (1713)
社区积分 1 (43006)
注册日期 2006-10-8
论坛徽章:1
#9
使用道具
发表于 2008-9-24 12:16
回复 #6 Laurence.li 的帖子
怎么可能会一样
SQL> with tab as(select 1 col from dual
2 union all select 2 col from dual
3 union all select 3 col from dual
4 union all select 4 col from dual)
5 select col from (select col,rownum rn from tab order by col desc) where rn<3;
COL
----------
2
1
SQL> with tab as(select 1 col from dual
2 union all select 2 col from dual
3 union all select 3 col from dual
4 union all select 4 col from dual)
5 select col from (select col,rownum rn from tab order by col desc) where rownum<3;
COL
----------
4
3
SQL>
__________________
别揣着糊涂装明白
只看该作者
dingjun123
djゆoracle
来自 china
精华贴数 3
个人空间
0
技术积分 1915 (912)
社区积分 15 (8980)
注册日期 2006-7-28
论坛徽章:2
#10
使用道具
发表于 2008-9-24 12:24
QUOTE:
原帖由
Laurence.li
于 2008-9-24 12:05 发表
三楼的写法比较正规
但楼主的第二种写法结果也一定是正确的,因为rownum列的结果永远是从1开始,查询对这个列的赋值应当是在order by操作之后的。
搂主的两种写法都不对的。但是搂主的第二种写法如果只要求输出前15条,那么是正确的,但是ronum的顺序就乱了,不是自然排序!
__________________
软件体系架构要以数据库为中心,如oracle,可以充分利用数据库的特性,帮助解决复杂的问题。一个常用的规则是:
如果能用单条sql解决,ok
如果不能用单条sql解决,考虑使用PL/SQL
如果不能用PL/SQL解决,考虑使用java存储过程
如果不能用java解决,那么考虑使用c外部过程
如果c都解决不了,那么考虑一下放弃吧
只看该作者
12
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号
联系我们
法律顾问
控制面板首页
编辑个人资料
积分交易
公众用户组
好友列表
升级个人空间
基本概况
论坛排行
主题排行
发帖排行
积分排行
在线时间
管理团队
管理统计