1
我是新來的django,需要做一個查詢。我可以在sql中完成,但我似乎無法在django中找到它。這裏是在SQL中。有人能告訴我如何在Django中做到這一點。Django多連接查詢
select token from api_userprofile
join api_userdevice on api_userdevice.user_id=api_userprofile.user_id
join api_device on api_device.id=api_userdevice.device_id
where api_device.serial=3
我的模式是這樣的:
class UserDevice(models.Model):
user = models.ForeignKey(settings.AUTH_USER_MODEL, on_delete=models.PROTECT, null=False)
device = models.ForeignKey(Device, on_delete=models.PROTECT, null=False)
activation_date = models.DateTimeField(default=timezone.now, null=False)
friendly_name = models.CharField(max_length=20, null=True, blank=True)
is_owner = models.BooleanField(null=False, default=False)
is_admin = models.BooleanField(null=False, default=True)
class Device(models.Model):
serial = models.CharField(max_length=16, null=False, unique=True)
publickey = models.CharField(max_length=44, null=False)
class UserProfile(models.Model):
user = models.ForeignKey(settings.AUTH_USER_MODEL,on_delete=models.PROTECT, null=False)
token = models.TextField(null=False, blank=True)
它給我一個AttributeError:'QuerySet'對象沒有屬性'values__list'錯誤。我試圖做的是返回共享設備的用戶的所有令牌_序列號 –
沒關係我想通了。 values__list需要是value_list。謝謝!!! –
抱歉錯字!很高興幫助你) –