Dataset untuk kursor disiapkan oleh server pada saat eksekusi FETCH pertama. Aplikasi klien hanya menerima hasil pernyataan FETCH berikutnya.
Jika server tidak dapat menggunakan indeks untuk mempertahankan kursor, kumpulan data sementara dibuat. Anda dapat melakukan tes sederhana ini:
create table test(i int, v text);
insert into test
select i, i::text
from generate_series(1, 5000000) i;
Jalankan pernyataan dalam skrip ini satu per satu:
begin;
declare cur cursor
for select * from test
order by random(); -- 17 ms
fetch next cur; -- 37294 ms (*)
fetch next cur; -- 0 ms
fetch prior cur; -- 0 ms
fetch absolute 1000000 cur; -- 181 ms
fetch relative 1000000 cur; -- 163 ms
fetch first cur; -- 0 ms
fetch last cur; -- 0 ms
rollback;
First FETCH (*) bekerja kira-kira pada waktu yang hampir bersamaan dengan pembuatan tabel sementara yang serupa:
create temp table temp_test as
select * from test
order by random(); -- 51684 ms
Beberapa driver mungkin memiliki implementasi kursor sendiri di sisi klien. Ini harus dijelaskan secara eksplisit dalam dokumentasi pengemudi.