多対多の関係を介して別のモデルによってリンクされている2つのモデルがあります。
これがモデル自体です
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')
そして、おいしいリソース
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の場合にのみ、リンクされた結果を返すことはできますか?
私はこのフィルター属性をtastypieで試しましたが、リンクを実行している実際のテーブルではなく、リンクされたテーブル(つまりタグまたは投稿)のフラグのみを考慮しているようです。