Django Tastypie:加入两个模型

Django Tastypie : Join two model

我是 django 和 tastypie 的新手。我想加入两个模型,即 order 和 order_item 以根据订单 ID 从它们中获取数据。我参考了一些来源,但仍然没有在两个模型中显示数据。

订单型号:

user = models.ForeignKey(USER_MODEL, blank=True, null=True,
            verbose_name=_('User'))
    status = models.IntegerField(choices=STATUS_CODES, default=PROCESSING,
            verbose_name=_('Status'))
    order_subtotal = CurrencyField(verbose_name=_('Order subtotal'))
    order_total = CurrencyField(verbose_name=_('Order Total'))
    shipping_address_text = models.TextField(_('Shipping address'), blank=True,
        null=True)
    billing_address_text = models.TextField(_('Billing address'), blank=True,
        null=True)
    created = models.DateTimeField(auto_now_add=True,
            verbose_name=_('Created'))
    modified = models.DateTimeField(auto_now=True,
            verbose_name=_('Updated'))
    cart_pk = models.PositiveIntegerField(_('Cart primary key'), blank=True, null=True)
    userid_consgeo = models.TextField(blank=True, null=True)
    cartid_consgeo = models.TextField(blank=True, null=True)

OrderItem 的型号:

order = models.ForeignKey(get_model_string('Order'), related_name='items',
            verbose_name=_('Order'))
    layer_reference = models.CharField(max_length=255,
            verbose_name=_('Layer reference'))
    layer_name = models.CharField(max_length=255, null=True, blank=True,
            verbose_name=_('Layer name'))
    layer = models.ForeignKey((ResourceBase),
            null=True, blank=True, **f_kwargs)
    unit_price = CurrencyField(verbose_name=_('Unit price'))
    quantity = models.DecimalField(verbose_name=_('Quantity'), default=0.00, max_digits=12, decimal_places=2)
    line_subtotal = CurrencyField(verbose_name=_('Line subtotal'))
    line_total = CurrencyField(verbose_name=_('Line total'))

我的资源:

class OrderItemResources(ModelResource):
    order_id = fields.CharField(attribute='order_id')
    layer_id = fields.CharField(attribute='layer_id')
    all_order = fields.ToManyField('resources.JoinOrderResources', 'all_order_set', related_name = 'all_order', full=True)

    class Meta:
        queryset = OrderItem.objects.all()
        resource_name = 'order_item'

        filtering = {
            "layer_id": ALL_WITH_RELATIONS,
            "order_id": ALL_WITH_RELATIONS,
        }

class JoinOrderResources(ModelResource):
    id = fields.CharField(attribute='id')
    user = fields.CharField(attribute='user')
    order_id = fields.ForeignKey(OrderItemResources, 'order_item', full=True, null=True)
    class Meta:
        queryset = Order.objects.all()
        resource_name = 'all_order'
        list_allowed_methods = ['get']
        authorization = Authorization()

        filtering = {
           "id": ALL,
           "user": ALL_WITH_RELATIONS,
        }

您在 OrderItem-Model 中设置了 related_name='items'。所以你想要做的是:

class OrderResource(ModelResource):
     id = fields.CharField(attribute='id')
     user = fields.CharField(attribute='user')
     # order_id = fields.ForeignKey(OrderItemResources, 'order_item', full=True, null=True)
     items = fields.ToManyField(OrderItemResources, 'items', full=True, null=True)


    class Meta:
        queryset = Order.objects.all()
        resource_name = 'order_item'

    filtering = {
        "id": ALL,
        "user": ALL_WITH_RELATIONS,
    }