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

how can I fetch the specific ids data( multiple ids are stored in list) using Django

我想获取用户界面提供的多个 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)

您可以使用 filter(pk__in=pk).

尝试:

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

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