取得したすべてのデータをページ付けするのではなく、実際のページ付けを行う必要があります。Djangoドキュメントサイトの例は次のようになります。
def listing(request):
contact_list = Contacts.objects.all()
paginator = Paginator(contact_list, 25) # Show 25 contacts per page
page = request.GET.get('page')
try:
contacts = paginator.page(page)
except PageNotAnInteger:
# If page is not an integer, deliver first page.
contacts = paginator.page(1)
except EmptyPage:
# If page is out of range (e.g. 9999), deliver last page of results.
contacts = paginator.page(paginator.num_pages)
return render_to_response('list.html', {"contacts": contacts})
このコードは、取得したすべてのレコードのレコードをページ分割しています。しかし、問題があります。レコードが非常に多い場合、すべてのレコードを取得しようとすると時間がかかります。データベースからページごとにレコードを取得するためのソリューションが必要です。
Djangoでこれを行う別の解決策はありますか?