如何使用 Django 获取特定的 id 数据(多个 id 存储在列表中)

Posted

技术标签:

【中文标题】如何使用 Django 获取特定的 id 数据(多个 id 存储在列表中)【英文标题】:how can I fetch the specific ids data( multiple ids are stored in list) using Django 【发布时间】:2021-08-14 00:04:38 【问题描述】:

我想获取从用户界面提供的多个 id 的数据,这些 id 存储在一个列表中。那么如何使用 Django ORM 检索这些 id 的数据呢? 当我尝试以下方法时它什么也没返回

def selectassess(request):
    if request.method=='POST':
        assess=request.POST.getlist("assess")
        quesno=request.POST.getlist("quesno")
        subid=request.POST.getlist("subid")
        print(quesno,subid)
        
        print(assess)
        max_id = Sub_Topics.objects.all().aggregate(max_id=Max("id"))['max_id']
        print(max_id)
        
        pk = random.sample(range(1, max_id),3)
        
        subss=Sub_Topics.objects.raw("Select * from Sub_Topics where id=%s",(str(pk),))
        
        context4=
            'subss':subss,
            

        
        print(pk)
        return render(request,"assessment.html",context)

通过应用下面提到的方法,我只能获得一个通过键入索引值指定的 id-data。但是我想获取存储在列表中的所有 id 的数据,那么如何使用 Django ORM 获得所需的输出

def selectassess(request):
    if request.method=='POST':
        assess=request.POST.getlist("assess")
        quesno=request.POST.getlist("quesno")
        subid=request.POST.getlist("subid")
        print(quesno,subid)
        print("youuuuu") 
        print(assess)
        max_id = Sub_Topics.objects.all().aggregate(max_id=Max("id"))['max_id']
        print(max_id)
        
        pk = random.sample(range(1, max_id),3)
        sub = Sub_Topics.objects.filter(pk=pk[0]).values('id','subtopic')
        
        
        context4=
            
            'sub':sub,

        
        print(pk)
        return render(request,"assessment.html",context4)

【问题讨论】:

【参考方案1】:

试试:

list_of_ids = random.sample(range(1, max_id),3)

sub = Sub_Topics.objects.filter(id__in=list_of_ids).values('id','subtopic')

【讨论】:

【参考方案2】:

您可以使用filter(pk__in=pk)

【讨论】:

以上是关于如何使用 Django 获取特定的 id 数据(多个 id 存储在列表中)的主要内容,如果未能解决你的问题,请参考以下文章

如何从 django 模板中的 for 循环中获取特定的 id?

如何在一对多核心数据关系中获取特定数据?

django模型,如何动态设置查询的字段?

从具有多对多关系 django 的两个表中过滤数据

Django Angularjs如何调用具有特定ID的Http请求

django在读取数据库后返回的是一个对象,如何将对象中的字段(属性)读出?