使用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获取该数据的上一条和下一条方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持创新互联。
售后响应及时
7×24小时客服热线数据备份
更安全、更高效、更稳定价格公道精准
项目经理精准报价不弄虚作假合作无风险
重合同讲信誉,无效全额退款