首页 文章

Django查询:获取两个关系的数据

提问于
浏览
1

我已经google了很多次并多次阅读这个网站https://docs.djangoproject.com/en/1.11/topics/db/queries/但我仍然有问题要获得正确的数据 .

我使用MAC-Adress扩展了标准的Django-User-Model,因为我稍后会需要它 . 我也有这样的模型之间的关系:

一个“Django-Standard-User”有一个UserProfile

ONE“UserProfile”有很多CalData

from django.contrib.auth.models import User

class UserProfile(models.Model):
    user = models.OneToOneField(User)
    mac = models.CharField(max_length=17, default='00:00:00:00:00:00')

    def __str__(self):
        return self.user.username

class CalData(models.Model):
    user = models.ForeignKey(UserProfile)
    date = models.DateField(default="1970-01-01")
    timestamp = models.TimeField(default="00:00:00")
    entry_id= models.CharField(max_length=100, default="NoID")

现在从用户登录后,我想进行如下查询:“给我一个Caldata查询(不是对象),其中user =”Standard-Django-User的用户名“,其中Date =今天 .

第二个问题是:将Caldata的ForeignKey设置为“UserProfile”是否更好,或者将其设置为“User”(标准Django-Model)更好 . 我的目标是说:一个用户有一个独特的MAC地址和许多CalData .

1 回答

  • 0

    第一个问题:

    CalData.objects.filter(user__user__username=request.user.username)
    

    为用户提供用户名 . Django中的双下划线表示法非常强大,可以让您遍历表格 . 如果您拥有正确的中间件,则每个登录的请求都应该有一个用户字段 .

    第二个问题:如果用户没有UserProfile,您是否希望他们能够与CalData关联?如果是,请链接到User,如果没有,则链接到UserProfile .

相关问题