看板 java 關於我們 聯絡資訊
因為 OracleDB 沒有 LIMIT OFFSET 之類的用法, 假設我們要取第100000筆之後的300筆資料, 目前有看到有看到幾種模擬 LIMIT的方法,像是: 1. 子查詢先用 ROWNUM 將每筆編號直到100300號 然後父查詢再取出編號大於100000的 2. 第一次查詢用 ROWNUM 限制100300筆 第二次查詢用 ROWNUM 限制100000筆 將兩次查詢結果相減(MINUS) 之類的解法, (因為 DB 用 ORDER BY 會非常慢,類似解法省略) 看起來好像都沒有顯著差異,時間看起來沒比較快 我在想直接 executeQuery(sql) 將返回的 ResultSet rs.next() 重複100000次 然後取後面的300筆資料,這樣是不是可以接受? -- ※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 218.161.45.91 ※ 文章網址: https://www.ptt.cc/bbs/java/M.1502362544.A.4D6.html zelkova:轉錄至看板 Database 08/10 18:56
b92310051: 直接從sql下手就好了吧 >10000and <=10300不好嗎? 08/11 20:49
adrianshum: Oracle 就 select * from (select xxx from yyy order 08/11 22:00
adrianshum: by zzz) where rownum > 10000 and rownum <= 10300 08/11 22:00
ssccg: 不就原po的方法1? 08/12 10:37
swpoker: 這樣不知道耗多少的傳輸 08/15 00:12
adrianshum: Ssccg: 不是。原post 說在子查詢先限制100300 行。這 09/11 19:20
adrianshum: 做法不行。 09/11 19:20