您好,登錄后才能下訂單哦!
使用Django的ORM操作的時候,想要獲取本條,上一條,下一條。
初步的想法是寫3個ORM,3個ORM如下:
本條:models.Obj.objects.filter(id=n).first()
下一條:models.Obj.objects.filter(id__gt=n).all().order_by("id").first()
【注1:大于本條的第一個即是下一條】
【注2:因為默認的asc排序,可以簡化后面的】
上一條:models.Obj.objects.filter(id__lt=n).all().ordery_by("-id").first()
【注:小于本條的一定要是最后一條數據才是下一條,不然取出來的永遠是第一條】
【注:有last方法后面3個方法可以用.last()替代】
后面簡化了一下:
objs=models.Obj.objects.all().order_by("id")
本條:objs.filter(id=n).first()
下一條:objs.filter(id__gt=n).first()
上一條:objs.filter(id__lt=n).all().ordery_by("-id").first()
【注:有last方法的可以直接objs.filter(id__lt=n).last()了】
以上這篇Django獲取該數據的上一條和下一條方法就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。