錯(cuò)誤寫(xiě)法:
select a.*, rownum rfrom (select * from lg_order o order by o.order_id) awhere rownum <= 20 and rownum >= 10

正確寫(xiě)法:
select *from (select a.*, rownum r from (select * from lg_order o order by o.order_id) a where rownum <= 20) bwhere r >= 10
第一句是錯(cuò)誤的,由于rownum是一個(gè)總是從1開(kāi)始的偽列,Oracle 認(rèn)為這種條件不成立,查不到記錄
SQL的執(zhí)行順序從內(nèi)到外,從右到左。