Django获取该数据的上一条和下一条方法
使用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获取该数据的上一条和下一条方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持【听图阁-专注于Python设计】。