Paging dalam oracle ialah teknik yang digunakan untuk mendapatkan set hasil pangkalan data untuk mengurangkan penghantaran rangkaian dan penggunaan memori dengan membahagikan set hasil kepada bahagian yang lebih kecil Menggunakan kata kunci dan subquery "ROWNUM", pengaturcara boleh dengan mudah Melaksanakan fungsi paging dan memilih blok data tertentu untuk dipaparkan mengikut keperluan pengguna.
Persekitaran pengendalian tutorial ini: sistem Windows 10, Oracle versi 19c, komputer DELL G3.
Dalam Oracle, paging ialah teknik yang digunakan untuk mendapatkan semula set hasil pangkalan data. Ia membolehkan pengaturcara memaparkan sejumlah besar data pada berbilang halaman, dibahagikan dan dipaparkan mengikut keperluan pengguna.
Dalam pertanyaan pangkalan data tradisional, apabila sejumlah besar data perlu diambil, pangkalan data mengembalikan semua hasil kepada pelanggan. Ini boleh menyebabkan kependaman rangkaian dan isu penggunaan memori, terutamanya apabila set hasil adalah sangat besar. Untuk menyelesaikan masalah ini, teknologi paging telah wujud.
Paging membolehkan pengaturcara membahagikan set hasil menjadi bahagian yang lebih kecil, hanya mengembalikan satu halaman data pada satu masa. Ini mengurangkan jumlah data yang dipindahkan melalui rangkaian dan membolehkan pengurusan penggunaan memori yang lebih baik.
Dalam Oracle, paging biasanya dilaksanakan menggunakan kata kunci ROWNUM dan subquery. ROWNUM ialah lajur pseudo khusus Oracle yang memberikan nombor unik kepada setiap baris yang dikembalikan. Dengan menggunakan ROWNUM, pengaturcara boleh mengehadkan saiz set hasil dan memilih sebahagian daripada data yang dikembalikan.
Berikut ialah contoh pertanyaan yang menunjukkan cara melakukan paging dalam Oracle:
SELECT * FROM ( SELECT t.*, ROWNUM AS rn FROM ( SELECT * FROM your_table ORDER BY your_column ) t WHERE ROWNUM <= :end_row ) WHERE rn >= :start_row;
Dalam pertanyaan ini, kami mula-mula mengisih set hasil asal (ORDER BY your_column). Kami kemudian memproses hasil pertanyaan sebagai subquery(t) dan memberikan setiap baris nilai ROWNUM. Dalam pertanyaan luar, kami menggunakan klausa WHERE untuk mengehadkan bilangan baris yang dikembalikan dan memilih blok data tertentu dengan menetapkan baris mula (:start_row) dan baris akhir (:end_row).
Dengan melaraskan nilai baris mula dan baris akhir, pengaturcara boleh memaparkan blok data yang berbeza pada halaman yang berbeza. Sebagai contoh, jika setiap halaman memaparkan 10 baris data, baris permulaan dan akhir halaman pertama ialah 1 dan 10, masing-masing, halaman kedua ialah 11 dan 20, dan seterusnya.
Perlu diambil perhatian bahawa ROWNUM dalam Oracle diperuntukkan selepas baris dipilih, jadi kita perlu menggunakan subquery bersarang untuk melaksanakan fungsi paging dengan betul.
Selain ROWNUM, Oracle juga menyediakan beberapa fungsi dan kata kunci lain untuk paging, seperti ROW_NUMBER, OFFSET dan FETCH FIRST. Fungsi ini boleh dipilih dan digunakan mengikut keperluan tertentu.
Untuk meringkaskan, paging dalam Oracle ialah teknik yang digunakan untuk mendapatkan dan memaparkan sejumlah besar data. Ia mengurangkan pemindahan rangkaian dan penggunaan memori dengan membahagikan hasil yang ditetapkan kepada bahagian yang lebih kecil. Menggunakan kata kunci dan subquery ROWNUM, pengaturcara boleh melaksanakan fungsi paging dengan mudah dan memilih blok data tertentu untuk paparan berdasarkan keperluan pengguna.
Atas ialah kandungan terperinci Apa itu paging dalam oracle. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!