Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/python/351.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python 是否从联接中检索所有值?_Python_Django - Fatal编程技术网

Python 是否从联接中检索所有值?

Python 是否从联接中检索所有值?,python,django,Python,Django,我有三张桌子用户、帖子和共享。Post是一个包含所有帖子的表Post与Share有一对多的关系。也就是说,Share表是一个表,它指示用户共享了哪些帖子。以下是表格的结构: class Post(models.Model): user = models.ForeignKey(User, on_delete=models.CASCADE) status = models.CharField(max_length=200) share_count =

我有三张桌子<代码>用户、帖子和共享。
Post
是一个包含所有帖子的表
Post
Share有一对多的关系。
也就是说,
Share
表是一个表,它指示用户共享了哪些帖子。以下是表格的结构:

class Post(models.Model):
    user        = models.ForeignKey(User, on_delete=models.CASCADE)
    status      = models.CharField(max_length=200)

    share_count = models.IntegerField(default=0)

    created_at  = models.DateTimeField(auto_now_add=True)
    url         = models.CharField(max_length=150)

class Share(models.Model):
    post        = models.ForeignKey(Post, on_delete=models.CASCADE)
    user        = models.ForeignKey(User, on_delete=models.CASCADE)
    shared_at   = models.DateTimeField(auto_now_add=True)
假设我们有一个id为1的用户。我想做的是显示该用户按日期排序的所有帖子+共享。就像你访问用户的Twitter档案时Twitter所做的那样。它显示了他们所有的推文+按日期和时间排序的转发。我尝试做的是这样一个查询:

Share.objects.all().select_related('post').get(user=1)
如果我这样做,我会得到一个错误,即此用户有多个共享。我做错了什么? 错误:

Example.models.multipleObject返回:get()返回了多个 共享--它返回2


您应该将
get()
替换为
filter()


请参阅和的文档,您应该将
get()
替换为
filter()

请参阅和的文档。如果未返回任何对象或返回多个对象,get()将返回错误。使用
.filter()
获取查询集:

Share.objects.all().select_related('post').filter(user=1)
如果未返回任何对象或返回多个对象,
.get()
将返回错误。使用
.filter()
获取查询集:

Share.objects.all().select_related('post').filter(user=1)

Share.objects.all().select_related('post').filter(user=1)
?@Rakesh-Hmm,这是可行的,但是,它只获取用户1的共享,而不获取他们的帖子。我需要获取用户1的共享和帖子
Share.objects.all()。选择相关('post')。筛选(user=1)
?@Rakesh-Hmm,这是可行的,但是,它只获取用户1的共享,而不获取他们的帖子。我需要获得用户1的共享和postsHmm,这是可行的,但是,它只获得用户1的共享,而不是他们的问题。我需要获得用户1的共享和questions@user2896120,什么问题?这将获得与用户1相关的所有
共享。当您遍历共享时,可以使用
Share.post
访问帖子及其属性。抱歉,它只显示用户的共享,而不显示用户的帖子。例如,我想要用户共享的内容+用户的帖子。因此,一个用户可以共享另一个用户的帖子,也可以发布自己的帖子如果您想要用户共享的内容:
Share.objects.filter(user=1)
如果您想要用户的帖子:
Post.objects.filter(user=1)
我想要共享和用户的帖子,但我之所以希望在一个查询中使用它,是因为我试图获得总共20个最新的共享+postsHmm,这是可行的,但是,它只获得用户1的共享,而不是他们的问题。我需要获得用户1的共享和questions@user2896120,什么问题?这将获得与用户1相关的所有
共享。当您遍历共享时,可以使用
Share.post
访问帖子及其属性。抱歉,它只显示用户的共享,而不显示用户的帖子。例如,我想要用户共享的内容+用户的帖子。因此,一个用户可以共享另一个用户的帖子,也可以发布自己的帖子如果您想要用户共享的内容:
Share.objects.filter(user=1)
如果您想要用户的帖子:
Post.objects.filter(user=1)
我想要共享和用户的帖子,但我之所以希望在一个查询中使用它,是因为我正在尝试获取总共20个最新的shared+postsHmm,这是可行的,但是,它只获取用户1的共享,而不获取他们的帖子。我需要获得用户1的共享和postsHmm,这是可行的,但是,它只获得用户1的共享,而不是他们的帖子。我需要获得用户1的共享和帖子