sybase临时表分页问题,union all 第二个结果集row_num始终是0,分页不正确

gelyon 2011-11-18 02:33:14

首先非常感谢大家对我上次sybase问题的回答,本人对sybase刚接触,很多不懂,请大家见谅。

现在又遇到个关于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,其它oracle\db2\sqlserver都支持,我郁闷到了。。
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_TEST AS(
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,而不是递增的顺序值呢?


...全文
340 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
gelyon 2011-11-19
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 baiynije 的回复:]
我試的有值啊

SELECT row_num=identity(16),tmpData.* into #tmptalbe from
(
SELECT prosscode ,prossname FROM borprc where prosscode <= '020'
UNION ALL
SELECT wrcode,wrcode FROM bororg where wrcode <= '……
[/Quote]
为什么我这第二个union 的结果集ROW_NUM就全是0呢??怎么回事?谁能告诉我一下,虽然我现在没再数据库端做分页,改在应用端做查询分页了。
baiynije 2011-11-18
  • 打赏
  • 举报
回复
我試的有值啊

SELECT row_num=identity(16),tmpData.* into #tmptalbe from
(
SELECT prosscode ,prossname FROM borprc where prosscode <= '020'
UNION ALL
SELECT wrcode,wrcode FROM bororg where wrcode <= '020'
) tmpData;

select * from #tmptalbe ;


1 017 清洗
2 015 洗管
3 018 噴粉
4 020 縮口(一)
5 005 拉管
6 010 裁切
7 001 備管生產
8 015N 洗管(新)
9 010N 裁切(新)
10 012 刷毛邊
11 012N 刷毛邊(新)
12 001 001
13 010 010

2,596

社区成员

发帖
与我相关
我的任务
社区描述
Sybase相关技术讨论区
社区管理员
  • Sybase社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧