我有两个模型通过多对多关系由另一个模型链接。Tastypie,过滤多对多关系
这里的模型本身
class Posts(models.Model):
id = models.CharField(max_length=108, primary_key=True)
tags = models.ManyToManyField('Tags', through='PostTags')
class Tags(models.Model):
id = models.CharField(max_length=108, primary_key=True)
posts = models.ManyToManyField('Posts', through='PostTags')
class PostTags(models.Model):
id = models.CharField(max_length=108, primary_key=True)
deleted = models.IntegerField()
post_id = models.ForeignKey('Posts', db_column='post_field')
tag_id = models.ForeignKey('Tags', db_column='tag_field')
而且tastypie资源
class PostsResource(ModelResource):
tags = fields.ToManyField('django_app.api.TagsResource', 'tags', null=True)
class Meta:
queryset = Posts.objects.filter(deleted=0)
resource_name = 'posts'
class TagsResource(ModelResource):
posts = fields.ToManyField('django_app.api.PostsResource', 'posts', null=True)
class Meta:
queryset = Tags.objects.filter(deleted=0)
resource_name = 'tags'
在posttags桌子上有一个删除标志,是否有可能只返回链接的结果时,在PostTags删除标志是0?
我试过this tastypie中的filter属性,但它似乎只关心链接表(即标签或帖子)中的标志而不是实际的链接表。
您是否尝试过'查询集= Posts.objects.filter(posttags__deleted = 0)'梅塔对于每个资源? – astevanovic 2012-07-19 12:24:33
这很奇怪,那是一半的作品。就像我打印queryset.query一样,它正在执行正确的SQL语句(就像它在delete = 0的地方那样)。但通过api请求返回的结果似乎仍然忽略了该标志。 – Shane 2012-07-19 13:54:41