免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 6576 | 回复: 9
打印 上一主题 下一主题

有没有类似于oracle 的 rownum 的功能 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2006-01-20 15:22 |只看该作者 |倒序浏览

在informix中,是否有类似于oracle中rownum的功能
在db2中可以通过 row_number() over() 来计算
oracle中也可以,是否informix中也有?

谢谢先!
-----------------------------------------------------------
正在做从oracle移植到DB2和INFORMIX,DB2的完成了
做分页时需要用到这些功能,如果没有类似的功能,重写代码麻烦就大了
---------------------------------------------------------------------

论坛徽章:
0
2 [报告]
发表于 2006-01-20 22:57 |只看该作者

回复 1楼 ouygui 的帖子

if the table is not fragmented, you can try following :-
  select rowid, * from tabname

论坛徽章:
0
3 [报告]
发表于 2006-01-21 00:22 |只看该作者
select rowid, * from tabname
---------------------------------------
我想如果是从1开始,并且是连续的就好了
rowid也可以,不过需要重写应用程序的代码来支持,呜呜!

论坛徽章:
0
4 [报告]
发表于 2006-01-21 13:29 |只看该作者
呵呵,rowid在一个表中的值并不是唯一的,比如分片的表,有可能处于不同片上的两行,其rowid相同。
而oracle的rownum是返回集的行号,当然是唯一的,和rowid还是很大不同的。比如rownum的最大值就是返回结果的行数,而rowid则不是。

[ 本帖最后由 xxyyy 于 2006-1-21 13:31 编辑 ]

论坛徽章:
0
5 [报告]
发表于 2006-01-21 20:08 |只看该作者
不知道用INFORMIX做过WEB开发的兄弟,分页是怎么做的,在oracle和db2中,如果数据量不是很大,对性能要求也不是很高的情况下,可以使用 rownum来做,比如这样
oracle中:
select * from
(
    select rownum as rm,a.*
      from tableName a
         where conditions..........
)
where rm between n and n+10

db2:
select * from
(
    select row_number() as rm,a.*
      from tableName a
         where conditions..........
) as tb
where tb.rm between n and n+10

[ 本帖最后由 ouygui 于 2006-1-23 13:54 编辑 ]

论坛徽章:
0
6 [报告]
发表于 2006-01-23 15:50 |只看该作者
建个 跟原表一样的表,加上个 serial 字段,从1开始计数。
先把满足条件的记录插入到这个临时表,在临时表中按 serial 的值来取范围。

高版本的可以用 create sequence 来建个 从1 开始递增为1的序列 来用。

请做过web分页的DX来说说

[ 本帖最后由 wenlq 于 2006-1-23 15:51 编辑 ]

论坛徽章:
0
7 [报告]
发表于 2006-01-27 21:37 |只看该作者
楼上的真厉害

论坛徽章:
0
8 [报告]
发表于 2006-03-31 20:48 |只看该作者
真的没有办法?

informix数据库中没有一个支持数据库中队查询数据集分页的解决方法 ??

[ 本帖最后由 auto163 于 2006-3-31 20:50 编辑 ]

论坛徽章:
0
9 [报告]
发表于 2006-04-01 13:44 |只看该作者
没有直接的办法了,wenlq的方法是比较好的

论坛徽章:
0
10 [报告]
发表于 2006-04-01 23:29 |只看该作者
用滚动游标绝对定位也可以做到的吧,当然用一句SQL语句估计是做不到了。

不过表里建个serial型的字段+select first 语句,也不是做不到。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP