使用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进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。