关于django REST CRUD的简单示例

时间:2018-04-19 11:53:23

标签: django django-rest-framework crud

我正在为一家餐馆开发Django REST API项目。

我必须获取客户端请求,并且对于某些请求发送模型对象,并且对于更新或删除请求,请向客户端发送反馈。

假设我的models.py就像:

# models.py
---------------------------------------------------------------------------
class Table(models.Model):
    id = models.AutoField(primary_key=True)
    name = models.CharField(max_length=30, null=False, blank=False)
    is_free = models.BooleanField(default=True)

    def __str__(self):
        return '%s %s %s' % (self.id, self.name, self.is_free)


class Order(models.Model):
    order_id = models.AutoField(primary_key=True)
    table_id = models.ForeignKey(Table, on_delete=models.CASCADE)
    total_price = models.IntegerField()

    def __str__(self):
        return '%s %s' % (self.order_id, self.total_price)

我想发送客户端GET请求的所有订单列表,发送更新和删除请求的反馈,并发送True或False,无论具有从客户端发送的id的特定表是否空闲。 / p> 不幸的是,在阅读了这么多文件后我感到很困惑。

请您举一个简单的例子来实现这些目的吗?

之后你能给我一个如何为客户使用序列化无模型对象的例子吗?

提前致谢。

1 个答案:

答案 0 :(得分:2)

也许最简单的方法是使用ModelViewSetModelSerializer来提供基本的CRUD操作。

<强> serializers.py

class OrderSerializer(serializers.ModelSerializer):
    class Meta:
        model = Order
        fields = ('order_id', 'table_id', 'total_price')

<强> views.py

class OrderViewSet(viewsets.ModelViewSet):
    queryset = Order.objects.all()
    serializer_class = OrderSerializer
    filter_backends = (filters.DjangoFilterBackend,)
    filter_fields = ('table_id',)

<强> urls.py

from rest_framework import routers

router = routers.SimpleRouter()
router.register(r'orders', OrderViewSet)
urlpatterns = router.urls

获取所有订单:

http://host/orders/

按ID获取订单:

http://host/orders/123/

获取特定表格的所有订单:

http://host/orders/?table_id=456

使用PUT更新订单:

# PUT using form data total_price=100
http://host/orders/123/

# Response
{"order_id": 123, "table_id": 456, "total_price": 100}

使用DELETE删除订单:

# DELETE
http://host/orders/123/

# Response has no content

要查询具有特定ID的表是否空闲,您可以使用相同的方法,但使用TableViewSet

# Get a table with a specific id
http://host/tables/456/

然后评估您回来​​的JSON响应中的is_free属性。

# Response
{"id": 456, "name": "table name", "is_free": true}