NOT NULL constraint failed:orders_order.user_id
Я новичок в django и создаю сайт электронной коммерции. Когда я пытаюсь сделать новый заказ на моем сайте, я получаю эту ошибку: NOT NULL constraint failed:orders_order.user_id
каждый пользователь может иметь несколько заказов и я хочу показать заказы в профиле пользователя, но у меня проблема с размещением заказов
models.py
class Order(models.Model):
user = models.ForeignKey(get_user_model(), on_delete=models.CASCADE)
address = models.CharField(max_length=250)
postal_code = models.CharField(max_length=11)
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 f'Order {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 str(self.id)
def get_cost(self):
return self.price * self.quantity
forms.py
class OrderCreateForm(forms.ModelForm):
class Meta:
model = Order
fields = ['address', 'postal_code', 'city']
views.py
def order_create(request):
cart = Cart(request)
if request.method == 'POST':
user = request.user
form = OrderCreateForm(request.POST)
if form.is_valid():
order = form.save()
for item in cart:
OrderItem.objects.create(order=order, product=item['product'], price=item['price'],
quantity=item['quantity'])
context = {
'order': order,
}
# clear the cart
cart.clear()
return render(request, 'order/created.html', context)
else:
form = OrderCreateForm()
context = {'cart': cart,
'form': form,
}
return render(request, 'order/create.html', context)
шаблон
{% extends 'shared/_MainLayout.html' %}
{% block content %}
<h1>Checkout</h1>
<div class="order-info">
<h3>Your order</h3>
<ul>
{% for item in cart %}
<li>
{{ item.quantity }}x {{ item.product.name }}
<span>${{ item.total_price }}</span>
</li>
{% endfor %}
</ul>
<p>Total: ${{ cart.get_total_price }}</p>
</div>
<form method="post" class="order-form">
{{ form.as_p }}
<p><input type="submit" value="Place order"></p>
{% csrf_token %}
</form>
{% endblock %}
OrderCreateForm используется для создания заказа, но вы не указали поле user, поэтому вам следует добавить объект user в Order перед его сохранением в views.py когда вы вызываете form.save(), он пытается создать объект Order, но для этого заказа нет пользователя, поэтому вы получаете ошибку ограничения NOT NULL:orders_order.user_id
проблема решена: в файле views.py должно быть так:
order = form.save(commit=False)
order.user = request.user
order.save()