Как добавить данные в модель, на столбец которой ссылаются (Foreign Field) из другой модели в Django
Я пытаюсь добавить данные в модель Cart, но получаю ошибку в виде
В поле, в которое я пытаюсь ввести данные, находится ForeignField, ссылка на которое - Items.
Невозможно присвоить "9": "Cart.pid" должен быть экземпляром "items".
Вот мой код:-
Views.py
def add_cart(request):
pid = request.POST.get('cart_id')
quantity = request.POST.get('quantity')
details = items.objects.filter(pk = request.POST.get('cart_id'))
name = None
price = None
for i in details:
name = i.name
price = i.price
pid = i.id
user_id = request.user.id
total = int(quantity)*price
instance = Cart(pid = pid,quantity = quantity,pro_name = name,pro_price = price,user_id = user_id,total = total)
return redirect('home')
Models.py
class items(models.Model):
id = models.AutoField(primary_key=True)
name = models.CharField(max_length=100,default='Item')
desc = models.TextField(max_length=500, default='Best')
price = models.IntegerField()
category = models.CharField(max_length=50,default='Product')
image = models.ImageField(upload_to="media",default='Item Image')
class Cart(models.Model):
pid = models.ForeignKey('items',on_delete=CASCADE,related_name="proid")
name = models.ForeignKey('items',on_delete=CASCADE,related_name="proname")
price = models.ForeignKey('items',on_delete=CASCADE,related_name="proprice")
quantity = models.IntegerField(default=1)
user_id = models.ForeignKey(User,on_delete=CASCADE)
total = models.IntegerField(default=0)
Помогите пожалуйста!!!
Когда мы используем внешний ключ в Django, мы можем использовать экземпляр связанного объекта или необработанное значение поля базы данных. В вашем коде есть поле с именем pid
. Вы можете присвоить ему экземпляр объекта:
for i in details:
name = i.name
price = i.price
pid = i # <!-- no i.id, i is the object instance
user_id = request.user.id
total = int(quantity)*price
instance = Cart(pid = pid,quantity = quantity,pro_name = name,pro_price = price,user_id = user_id,total = total)
...Или присвойте значение ключа (i.id
) магически созданному свойству pid_id
:
for i in details:
name = i.name
price = i.price
pid = i.id
user_id = request.user.id
total = int(quantity)*price
instance = Cart(pid_id = pid,quantity = quantity,pro_name = name,pro_price = price,user_id = user_id,total = total)
# We are ising the raw database value. W read it from `i.id` above.
instance.pid_id = pid