Django Rest Framework基于foreignkey用户字段的ViewSet过滤问题

问题描述 投票:1回答:1

我有一个我正在研究的django项目。该项目有两种模型。有一个useraccount模型。我正在整合django rest框架视图集。我将在下面包括它们。我现在正在将Django Rest Framework集成到项目中。我试图搞清楚如何做两件事。

2款:

默认的django用户

账户模型:

class Account(models.Model):
    user = models.ForeignKey(User, on_delete=models.CASCADE)
    _id = models.CharField(max_length=45)
    name = models.CharField(max_length=140)
    balance = models.DecimalField(max_digits=100, decimal_places=2)
    currency = models.CharField(max_length=12)
    bank_name = models.CharField(max_length=120)
    routing = models.CharField(max_length=8)
    _class = models.CharField(max_length=22)
    type = models.CharField(max_length=22)
    active = models.BooleanField(default=True)
    main = models.BooleanField(default=False)
    synapse = models.BooleanField(default=False)
    create_at = models.DateTimeField(auto_now_add=True)

    def __str__(self):
        return self.user.username + ' - ' + self.name + ': ' + str(self.balance)

1 =>我希望能够输入端点/api/users/accounts/omarjandlai并使用omarjandali用户外键获取单个或多个acounts

2 =>我希望能够输入以下api/users/accounts/并返回数据库中的所有帐户

我尝试了4到5种不同的方法让它工作,我无法让它工作。

这是我的序列化程序和视图

串行:

class AccountSerializer(serializers.ModelSerializer):
    class Meta:
        model = Account
        fields = ('user', '_id', 'name', 'balance', 'currency', 'bank_name',
                  'routing', '_class', 'type', 'active', 'main', 'synapse')

浏览次数:

class AccountViewSet(viewsets.ModelViewSet):
    queryset = Account.objects.all();
    serializer_class = AccountSerializer
    filter_backends = (filters.DjangoFilterBackend,)
    filter_fields = ('user',)

发生的事情是,当我这样做的时候

api/users/account我看到所有帐户

api/users/account/omarjandali我得到detail not found

网址:

router = DefaultRouter()
router.register(r'users', UserViewSet, basename='user')
router.register(r'accounts', AccountViewSet, basename='account')
urlpatterns = router.urls
django django-rest-framework django-rest-viewsets
1个回答
1
投票

我可以看到您正在使用DefaultRouter的默认功能。这样,您只能使用主键访问记录详细信息。由于您未明确指定任何字段作为主键(primary=True),因此Django设置字段ID,即PositiveIntegerField作为模型的主键。因此,如果要访问记录的详细信息,则必须使用api/users/account/112/

您可以使用过滤器按名称访问记录:api/users/account/?search='omarjandali',但您需要添加SearchFilter

from rest_framework.filters import SearchFilter 

class AccountViewSet(viewsets.ModelViewSet):
    queryset = Account.objects.all();
    serializer_class = AccountSerializer
    filter_backends = (filters.DjangoFilterBackend, SearchFilter)
    filter_fields = ('user',)
    search_fields = ('name',)

如果你想坚持url模式api/users/account/omarjandali/,你必须将它添加到urls.py并使用另一个视图集,以便让原始的一个相应地运行DefaultRouter定义:

URLs.朋友:

router = DefaultRouter()
router.register(r'users', UserViewSet, basename='user')
router.register(r'accounts', AccountViewSet, basename='account')

urlpatterns = [
    path('', include(router.urls)),
    path('api/users/account/<str:username>/', views.GetRecordsByNameViewSet.as_view({'get': 'list'}),
]

views.朋友

from rest_framework.response import Response

class GetRecordsByNameViewSet(viewsets.ViewSet):
    def list(self, request, username):
        accounts = Account.objects.filter(user__username=username)
        accounts_to_return = AccountSerializer(accounts, many=True).data

        return Response(accounts_to_return)
© www.soinside.com 2019 - 2024. All rights reserved.