willbeike 发表于 2007-11-22 11:10

存储过程应该如何调用啊?搞了半天不知道如何使用,郁闷!谢谢了

mcolinc 发表于 2008-02-21 20:32

创建表的时候设置一个identity的栏位
这样就可以做到分页取数据了

aliking 发表于 2008-02-26 20:41

同意17楼的观点,用游标更好一些。
用临时表算法的空间复杂度是O(n),如果表很大或没有预存在Cache中,所用的I/O时间就非常可观了。
用游标定位到指定的页,空间复杂度应该是O(1),虽然游标遍历记录比直接用Select稍慢一点,但考虑到分页应用中,每次只读取一页的内容,所以这个时间性能上的损失可以忽略。

gelyon 发表于 2011-11-18 13:59

虽然这个帖子已经很久了,但是小弟现在遇到个关于sybase临时表分页的问题,对于两个结果集union 后分页不正确。
例如:
SELECT row_num=identity(16),tmpData.* into #tmptalbe from
(
SELECT ACCOUNT_ID ,CARD_ID FROM T_ACCOUNT_CARD
UNION ALL
SELECT USER_ID,ROLE_ID FROM T_USER_ROLE
) tmpData
select * from #tmptalbe
--where row_num>=convert(int,1) and row_num<=convert(int,20)
drop table #tmptalbe


这样分页后不正确,因为union all 后面第二个结果集没有被分配row_num,始终是0,导致我分页不正确。

我尝试改写union all写法, 用full join 来实现,但是测试时才发现sybase居然不支持full join,郁闷到了。。
SELECT
      CASE WHEN A.ACCOUNT_ID IS NULL THEN B.USER_ID ELSE A.ACCOUNT_ID END ID1,
      CASE WHEN A.CARD_ID IS NULL THEN B.ROLE_ID ELSE A.CARD_ID END ID2
FROM T_ACCOUNT_CARD A FULL JOIN T_USER_ROLE B ON 1=2

另外我也测试了用视图来做,结果也不行,视图中用UNION ALL 连接的两个结果集,第二个结果集还是没有ROW_NUM,始终为0,导致sybase临时表分页也不正确。

CREATE VIEW V_TESTAS(
        SELECT ACCOUNT_ID ,CARD_ID FROM T_ACCOUNT_CARD
        UNION ALL
        SELECT USER_ID,ROLE_ID FROM T_USER_ROLE
)


SELECT row_num=identity(16),tmpData.* into #tmptalbe from
(
SELECT * FROM V_TEST
) tmpData
select * from #tmptalbe
--where row_num>=convert(int,1) and row_num<=convert(int,20)
drop table #tmptalbe


请问怎么来结果这个分页查询不正确,到底union all 后的第二个结果集为什么row_num始终是0,而不是递增的顺序值呢?

epstar 发表于 2012-10-27 17:26

一楼的位置好啊..

Eisen 发表于 2012-10-28 14:00

本帖最后由 Eisen 于 2012-10-28 14:00 编辑

gelyon 发表于 2011-11-18 13:59 static/image/common/back.gif
虽然这个帖子已经很久了,但是小弟现在遇到个关于sybase临时表分页的问题,对于两个结果集union 后分页不正 ...
那换个写法呢--
create table #tmptable (row_num int identity,account_id varchar( 8 ),card_id varchar(20))
go
insert #tmptable
SELECT ACCOUNT_ID ,CARD_ID FROM T_ACCOUNT_CARD
UNION ALL
SELECT USER_ID,ROLE_ID FROM T_USER_ROLE

select * from #tmptablewhere row_num>=convert(int,1) and row_num<=convert(int,20)

2BeSybPro 发表于 2012-10-30 00:14

我n年前写过一个通用的分页程序,见下面链接。
http://bbs.chinaunix.net/forum.php?mod=viewthread&tid=569169&page=1#pid3779459

用tempdb作为staging area,一定注意别把tempdb填满了。Temp table 最好建索引,插入temp table的语句一定要用index scan,否则会在tempdb中hold transaction而引起tempdb space issue。

wang_xue_m 发表于 2012-10-30 09:03

楼主,用BCP可以设置起始
页: 1 2 [3]
查看完整版本: 版本12.5.2,分页取数据的sql怎么写?谁能帮我