我有两个模型,一个定义用户,另一个定义这些用户的标签。我正在使用 Django REST Framework 创建 API。我希望能够查询至少包含标签 id 1 和 2 的用户。
例如,如果用户的标签是:[(1,2), (1,2,3), (2,3), (1,3)]
我希望查询返回[(1,2), (1,2,3)]
.
到目前为止,我已经成功地通过执行以下操作来查询具有给定标签的用户(假设 id=1):/api/users/?labels=1
,但我无法查询带有标签 1 和 2 的用户。我已经尝试过/api/users/?labels=1,2
or /api/users/?labels=1&labels=2
但它返回一些无效用户,即没有标签 1 或 2 的用户...
Github 测试仓库:
https://github.com/TheDimLebowski/drf-m2m-filter https://github.com/TheDimLebowski/drf-m2m-filter
Code:
模型.py
class Label(models.Model):
name = models.CharField(max_length = 60)
class User(models.Model):
labels = models.ManyToManyField(Label)
过滤器.py
class UserFilter(django_filters.FilterSet):
labels = django_filters.filters.BaseInFilter(
name='labels',
lookup_type='in',
)
class Meta:
model = User
fields = ('labels',)
序列化器.py
class LabelSerializer(serializers.ModelSerializer):
class Meta:
model = Label
fields = ('id','name')
class UserSerializer(serializers.ModelSerializer):
labels = LabelSerializer(many = True)
class Meta:
model = User
fields = ('labels',)
views.py
class UserViewSet(viewsets.ModelViewSet):
queryset = User.objects.all()
serializer_class = UserSerializer
filter_backends = (filters.DjangoFilterBackend,)
filter_class = UserFilter
filter_fields = ('labels',)