指定行数范围查询

1、行范围超出总行数,也能查到总行数记录

SELECT res.* from (SELECT t.*, COALESCE(max(RN) OVER(),0) as TOTAL FROM 
(SELECT LOG_ID, OP_SYS,OP_USER,TO_CHAR(OP_TIME,'yyyy-mm-dd hh24:mi:ss') as OP_TIME,
OP_TYPE, OP_OBJECT,COALESCE(FACTORY_EQUIPMENT,''),COALESCE(SUB_VERSION,''),COALESCE(MARKET_CODE,''),
COALESCE(ICS_TYPE,''),COALESCE(EFFECTIVE_DATE,''),COALESCE(EXPIRATION_DATE,''),
ROWNUMBER() OVER( ORDER BY LOG_ID DESC ) AS RN 
FROM TM_TBALE_LOG WHERE AIRLINE='CA' AND OP_OBJECT='E'  
UNION ALL 
SELECT null,null,null,null,null,null,null,null,null,null,null,null,null from SYSIBM.SYSDUMMY1) as t) as res 
WHERE res.RN BETWEEN 11 AND 12 OR res.RN IS NULL

2、行范围超出总行数,不能查到总行数记录

SELECT * FROM ( SELECT LOG_ID, OP_SYS,OP_USER,TO_CHAR(OP_TIME,'yyyy-mm-dd hh24:mi:ss') as OP_TIME, OP_TYPE, OP_OBJECT,OP_ID,
CLOB(EQUIPMENT_JSON),AIRLINE,FACTORY_EQUIPMENT,SUB_VERSION,MARKET_CODE,ICS_TYPE,EFFECTIVE_DATE,EXPIRATION_DATE,
ROWNUMBER() OVER( ORDER BY LOG_ID DESC ) AS RN, COUNT(*) OVER() TOTAL 
FROM TM_MSM_TABLE_LOG  WHERE OP_TIME >='2017-09-21' and OP_TIME <='2017-12-31' AND OP_OBJECT='M') AS t WHERE t.RN BETWEEN 1 and 6

 

转载于:https://www.cnblogs.com/fushou/p/8416329.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值