Oracle
 sql >> Baza danych >  >> RDS >> Oracle

Simple Select z klauzulą ​​where i offset nie działa w oracle

OFFSET 1 ROWS FETCH NEXT 10 ROWS ONLY jest dostępny w Oracle 12c.

Zamiast tego musisz wykonać zapytanie i uporządkować dane; następnie wygeneruj numer wiersza dla uporządkowanych wierszy; i na koniec filtruj według tych numerów wierszy. Te kroki muszą być wykonane we właściwej kolejności w zagnieżdżonych zapytaniach podrzędnych:

SELECT *
FROM   (
  SELECT t.*,
         ROWNUM AS rn
  FROM   (
    SELECT up.NAME AS upozilaName_bn,
           up.id AS upozila,
           dis.NAME AS districtName_bn,
           dis.id AS district,
           dv.NAME AS divisionName_bn,
           dv.id AS division,
           w.COUNTER_TYPE,
           w.COUNTER_ID,
           w.STATUS
    FROM X w
    left join  Y up ON w.UPOZILA = up.ID
    left JOIN  Z dis ON w.DISTRICT = dis.id
    left join  P dv ON w.DIVISION = dv.ID
    order by upozilaName_bn asc
  ) T
)
WHERE  rn BETWEEN 2 AND 11;



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Czekasz na zakończenie przesłanego zadania w Oracle PL/SQL?

  2. Proste przypisanie SQL zmiennej Oracle

  3. Oracle:Usuń duplikaty w grupie z tabeli z dołączeniem

  4. Jak zwrócić Oracle Cursor z zapisanego proc jako Client Dataset za pomocą Delphi i DBExpress?

  5. Ograniczenie podczas pobierania danych blob z Oracle