कर्सर के लिए डेटासेट पहले FETCH के निष्पादन के समय सर्वर द्वारा तैयार किया जाता है। क्लाइंट एप्लिकेशन को केवल बाद के FETCH स्टेटमेंट के परिणाम प्राप्त होते हैं।
यदि सर्वर कर्सर को बनाए रखने के लिए अनुक्रमणिका का उपयोग नहीं कर सकता है, तो अस्थायी डेटासेट बनाया जाता है। आप यह सरल परीक्षण कर सकते हैं:
create table test(i int, v text);
insert into test
select i, i::text
from generate_series(1, 5000000) i;
इस स्क्रिप्ट में दिए गए कथनों को एक-एक करके निष्पादित करें:
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;
पहला FETCH (*) लगभग उसी समय के आसपास प्रदर्शन करता है जब एक समान अस्थायी तालिका का निर्माण होता है:
create temp table temp_test as
select * from test
order by random(); -- 51684 ms
कुछ ड्राइवरों के पास क्लाइंट साइड पर कर्सर का अपना कार्यान्वयन हो सकता है। इसे ड्राइवर के दस्तावेज़ों में स्पष्ट रूप से वर्णित किया जाना चाहिए।