java - 遇到Oracle數(shù)據(jù)庫分頁查詢的問題
問題描述
是這樣的,我這個(gè)表中有KS_ZKZ這個(gè)字段,這個(gè)字段在表中并不是唯一的,每個(gè)學(xué)號(hào)都出現(xiàn)了多次,我現(xiàn)在想依據(jù)這個(gè)學(xué)號(hào)來進(jìn)行分頁查詢:首先把學(xué)號(hào)去重,并升序排列:
SELECT DISTINCT(KS_ZKZ) from ZK.T_BYSQ_KS_KC ORDER BY KS_ZKZ ASC
有了這個(gè)查詢結(jié)果后,想查詢這個(gè)結(jié)果的從rownum 為a到b的數(shù)據(jù):
SELECT KS_ZKZ,ROWNUM FROM(SELECT DISTINCT(KS_ZKZ) from ZK.T_BYSQ_KS_KC ORDER BY KS_ZKZ ASC)WHERE ROWNUM >=10 AND ROWNUM<=20
但是問題出現(xiàn)了:下面是查詢結(jié)果。。
為什么查不到呢?
問題解答
回答1:rownum只是一個(gè)偽列, 你里面那層需要查個(gè)rownum出來就行, 比如
SELECT KS_ZKZ FROM(SELECT DISTINCT(KS_ZKZ), ROWNUM rn from ZK.T_BYSQ_KS_KC ORDER BY KS_ZKZ ASC)WHERE rn between 10 AND 20 回答2:
rownum的判斷必須以1開始,比如=1,<5都是成立的,但是=2,>7都必須先將結(jié)果集查出來,通過子語句再查詢(rownum需要?jiǎng)e名)
相關(guān)文章:
1. Docker for Mac 創(chuàng)建的dnsmasq容器連不上/不工作的問題2. docker安裝后出現(xiàn)Cannot connect to the Docker daemon.3. docker - 如何修改運(yùn)行中容器的配置4. python3.x - python連oanda的模擬交易api獲取json問題第五問5. nignx - docker內(nèi)nginx 80端口被占用6. css3 - 沒明白盒子的height隨width的變化這段css是怎樣實(shí)現(xiàn)的?7. javascript - webpack熱加載配置不生效8. javascript - QWebEngineView 如何爬 angular 的動(dòng)態(tài)數(shù)據(jù)?9. java - SSH框架中寫分頁時(shí)service層中不能注入分頁類10. java - instance method中 static后的<K>是什么意思?
