Django Tastypie:按外键过滤
Django Tastypie: Filtering by ForeignKey
我希望 Django Tastypie return 通过外键过滤的查询。这是我的两个模型:
class Origin(models.Model):
country = models.CharField(max_length=1024)
class Fruits(models.Model):
origin = models.ForeignKey(Origin)
fruit_name = models.CharField(max_length=1024)
is_sweet = models.BooleanField()
quantity = models.IntegerField()
根据文档 here,我正在使用以下 resources.py:
class FruitResource(ModelResource):
class Meta:
queryset = Fruits.objects.all()
allowed_methods = ['get']
filtering = {
"origin": ('exact',)
}
这是我正在尝试访问的URL:
http://localhost:8000/api/v1/fruit/?format=json&origin__country=Nepal
访问 URL returns 以下输出:
{
"meta":
{
"limit": 20, "next": null, "offset": 0, "previous": null, "total_count": 2}, "objects":
[
{"fruit_name": "Apple", "id": 1, "is_sweet": true, "quantity": 10, "resource_uri": "/api/v1/fruit/1/"},
{"fruit_name": "Banana", "id": 2, "is_sweet": true, "quantity": 10, "resource_uri": "/api/v1/fruit/2/"}
]
}
我应该提到我使用这个 URL:
得到了相同的输出
http://localhost:8000/api/v1/fruit/?format=json
通过指定 Origin 的国家/地区属性来获取 Fruits 对象列表的正确方法是什么?
我能够根据 this answer 让它工作。为了其他人的利益,我在这里列出最终代码。
from tastypie.resources import ModelResource, fields, ALL_WITH_RELATIONS
from fruits.models import Fruits
from origin.models import Origin
class OriginResource(ModelResource):
class Meta:
queryset = Origin.objects.all()
resource_name = 'origin'
filtering = {
"country": ('exact',)
}
class FruitResource(ModelResource):
origin = fields.ForeignKey(OriginResource, 'origin', full=True)
class Meta:
queryset = Fruits.objects.all()
allowed_methods = ['get']
filtering = {
"origin": ALL_WITH_RELATIONS,
}
使用此代码,如果我点击 http://localhost:8000/api/v1/fruit/?format=json&origin__country=Nepal
,我将得到以下预期输出:
{"meta":
{"limit": 20, "next": null, "offset": 0, "previous": null, "total_count": 1},
"objects": [{
"fruit_name": "Apple", "id": 1, "is_sweet": true, "origin":
{"country": "Nepal", "id": 3, "resource_uri": ""},
"quantity": 10, "resource_uri": "/api/v1/fruit/1/"
}]
}
我希望 Django Tastypie return 通过外键过滤的查询。这是我的两个模型:
class Origin(models.Model):
country = models.CharField(max_length=1024)
class Fruits(models.Model):
origin = models.ForeignKey(Origin)
fruit_name = models.CharField(max_length=1024)
is_sweet = models.BooleanField()
quantity = models.IntegerField()
根据文档 here,我正在使用以下 resources.py:
class FruitResource(ModelResource):
class Meta:
queryset = Fruits.objects.all()
allowed_methods = ['get']
filtering = {
"origin": ('exact',)
}
这是我正在尝试访问的URL:
http://localhost:8000/api/v1/fruit/?format=json&origin__country=Nepal
访问 URL returns 以下输出:
{
"meta":
{
"limit": 20, "next": null, "offset": 0, "previous": null, "total_count": 2}, "objects":
[
{"fruit_name": "Apple", "id": 1, "is_sweet": true, "quantity": 10, "resource_uri": "/api/v1/fruit/1/"},
{"fruit_name": "Banana", "id": 2, "is_sweet": true, "quantity": 10, "resource_uri": "/api/v1/fruit/2/"}
]
}
我应该提到我使用这个 URL:
得到了相同的输出http://localhost:8000/api/v1/fruit/?format=json
通过指定 Origin 的国家/地区属性来获取 Fruits 对象列表的正确方法是什么?
我能够根据 this answer 让它工作。为了其他人的利益,我在这里列出最终代码。
from tastypie.resources import ModelResource, fields, ALL_WITH_RELATIONS
from fruits.models import Fruits
from origin.models import Origin
class OriginResource(ModelResource):
class Meta:
queryset = Origin.objects.all()
resource_name = 'origin'
filtering = {
"country": ('exact',)
}
class FruitResource(ModelResource):
origin = fields.ForeignKey(OriginResource, 'origin', full=True)
class Meta:
queryset = Fruits.objects.all()
allowed_methods = ['get']
filtering = {
"origin": ALL_WITH_RELATIONS,
}
使用此代码,如果我点击 http://localhost:8000/api/v1/fruit/?format=json&origin__country=Nepal
,我将得到以下预期输出:
{"meta":
{"limit": 20, "next": null, "offset": 0, "previous": null, "total_count": 1},
"objects": [{
"fruit_name": "Apple", "id": 1, "is_sweet": true, "origin":
{"country": "Nepal", "id": 3, "resource_uri": ""},
"quantity": 10, "resource_uri": "/api/v1/fruit/1/"
}]
}