简体   繁体   English

在三个表中的Django反向查询查询

[英]django reverse lookup query within three tables

I have three tables User, Users_clients, and Credits. 我有三个表User,Users_clients和Credits。 I want to list tables of current user's clients with their details and credit. 我想列出当前用户的客户及其详细信息和信誉的表。 If any client is listed in credit table then credit should return 0 where else it should return the credit value. 如果信用表中列出了任何客户,则信用应返回0,否则应返回信用值。

my model.py is 我的model.py是

class User_clients(models.Model):
user = models.ForeignKey(User, related_name='myuser')
client = models.ForeignKey(User, related_name='myclient')

class Credits(models.Model):
user = models.OneToOneField(User, on_delete=models.CASCADE)
credit = models.IntegerField(null=True, default=0)

my views.py is 我的views.py是

def clients(request):
try:
    data = User_clients.objects.order_by('-id').filter(user_id=request.user.id)[0:10]
except User_clients.DoesNotExist:
    data = None
return render(request, "client_list.html",{'title':"Client List",'clients':data,'active':'myclients','open':'clients'})

Thanks a lot in advance! 在此先多谢!

updating after your comment: 发表评论后更新:

from itertools import chain
from django.db.models import F


without_credit = User_clients.objects.filter(user=request.user, client__credits__is_null=True).annotate(credit=0)
with_credit = User_clients.objects.filter(user=request.user, 
client__credits__is_null=False).annotate(credit=F("client__credits__credit"))
data = chain(without_credit, with_credit)

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM