我有一个为另一个方法设置数据的函数。它这样做是为了限制对数据库的调用。
设置方法如下:
def get_customers(request):
customer_list = Customer.objects.filter(pk=request.user)
populated_customer = get_customer(request, customer_list)
执行处理的方法如下所示:
def get_customer(request):
for customer in customer_list:
if customer.id == 3:
# do something with this customer
而不是使用for循环来找到我需要的客户,如何在不进入数据库的情况下将其从列表中拉出来,因为我正在处理数百万条记录。
答案 0 :(得分:0)
你在这里做的似乎是把所有用户记录拉到python(django)内存中,然后通过循环遍历这个QuerySet来过滤它们。
更好的方法可能是将这些查询链接到您的数据库,这是由django QuerySet语言支持的。
查看有关chained filter methods的文档是明智的,但示例查询可能如下所示:
customer_list = Customer.objects.filter(pk=request.user).filter(id=3)
As shown here,这与以下内容不同:
customer_list = Customer.objects.filter(pk=request.user,id=3)