【问题标题】:Internet shop in django. How to filter orders by user?django 的网店。如何按用户过滤订单?
【发布时间】:2018-03-15 11:23:56
【问题描述】:

对于我的项目,我编写了帐户、购物车、订单和商店应用程序。

订单/型号:

from django.db import models
from shop.models import Product


class Order(models.Model):
    first_name = models.CharField(max_length=50)
    last_name = models.CharField(max_length=50)
    email = models.EmailField()
    address = models.CharField(max_length=250)
    postal_code = models.CharField(max_length=20)
    city = models.CharField(max_length=100)
    created = models.DateTimeField(auto_now_add=True)
    updated = models.DateTimeField(auto_now=True)
    paid = models.BooleanField(default=False)

    class Meta:
        ordering = ('-created',)

    def __str__(self):
        return 'Order {}'.format(self.id)

    def get_total_cost(self):
        return sum(item.get_cost() for item in self.items.all())


class OrderItem(models.Model):
    order = models.ForeignKey(Order, related_name='items',
                              on_delete=models.CASCADE)
    product = models.ForeignKey(Product, related_name='order_items',
                                on_delete=models.CASCADE)
    price = models.DecimalField(max_digits=10, decimal_places=2)
    quantity = models.PositiveIntegerField(default=1)

    def __str__(self):
        return '{}'.format(self.id)

    def get_cost(self):
        return self.price * self.quantity

帐户/模型为空

帐户/观看次数:

from django.contrib.auth import login as auth_login
from django.shortcuts import render, redirect
from .forms import SignUpForm
from orders.models import OrderItem, Order
from django.contrib.auth.decorators import login_required


def signup(request):
    if request.method == 'POST':
        form = SignUpForm(request.POST)
        if form.is_valid():
            user = form.save()
            auth_login(request, user)
            return redirect('/')
    else:
        form = SignUpForm()
    return render(request, 'accounts/signup.html', {'form': form})


@login_required
def account(request):
    my_orders = Order.objects.all()
    order_items = OrderItem.objects.all()
    return render(request, "accounts/my_acc.html",
                  {"my_orders": my_orders, "order_items": order_items})

正如您在帐户功能中看到的,我得到了所有订单,但我不知道如何过滤用户的订单。我想要的是 - 当用户输入他的帐户时,他可以看到他以前的所有订单。

我该怎么做?

【问题讨论】:

  • 要做到这一点,您首先需要有一种方法将Order 绑定到User,这是您目前没有的。您可能需要将ForeignKey 添加到您的Order 模型中,以便将订单与用户相关联。使用您当前的模型结构,无法为用户过滤订单,因为这两个模型之间没有关系。
  • 这是个问题。我不知道该怎么做,在帐户应用程序中我不编写自己的模型,在视图中我只是使用'from django.contrib.auth import login as auth_login'。所以我不知道如何将订单与用户联系起来。你知道怎么做吗?

标签: django orders webshop


【解决方案1】:

您首先需要将您的OrderUser 关联:

from django.contrib.auth import get_user_model

User = get_user_model()

class Order(models.Model):

    user = models.ForeignKey(User, on_delete=models.PROTECT, related_name='orders')
    # insert other fields here

请参阅referencing the user model 了解此处发生的情况。

现在您在OrderUser 之间建立了关系,这意味着您可以像这样过滤给定用户的订单:

def account(request):
    my_orders = Order.objects.filter(user=request.user)

首先创建订单时,您当然需要将OrderUser 相关联——创建订单的任何代码都需要这样做。

【讨论】:

    猜你喜欢
    • 2013-08-14
    • 2018-05-10
    • 2022-08-19
    • 2014-01-31
    • 1970-01-01
    • 2010-10-27
    • 2015-08-15
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多