Как решить проблему сообщения об ошибке: нет такого столбца: auctions_auction.image_url
Я создаю веб-сайт, на котором пользователи будут отправлять форму со ссылкой на изображение при создании нового объявления. Затем эта ссылка/url будет преобразована и отображена в виде изображения на сайте. Я продолжаю получать эту ошибку, когда загружаю детали формы, включая ссылку на изображение -
""OperationalError at /create/
нет такого столбца: auctions_auction.image_url.""
Как я могу убрать эту ошибку?
VIEWS.PY
from django.shortcuts import render, redirect
from .forms import AuctionForm
def create_listing(request):
form = AuctionForm()
if request.method == 'POST':
form = AuctionForm(request.POST, request.FILES)
if form.is_valid:
form.save()
return redirect('index')
else:
form = AuctionForm()
context = {'form': form}
return render(request, 'auctions/create-listing.html', context)
FORMS.PY
from .models import Auction
from django import forms
from django.forms import fields
class AuctionForm(forms.ModelForm):
class Meta:
model = Auction
fields = ['title', 'description', 'current_bid', 'image_url']
MODELS.PY
from django.db import models
from django.core.files import File
from urllib.request import urlopen
from tempfile import NamedTemporaryFile
class Auction(models.Model):
title = models.CharField(max_length=25)
description = models.TextField()
current_bid = models.IntegerField(null=False, blank=False)
users_bid = models.IntegerField(null=False, blank=False)
image_upload = models.ImageField(upload_to='images/')
image_url = models.URLField(verbose_name="URL", max_length=255, unique=True)
created_at = models.DateTimeField(auto_now_add=True)
def save(self, *args, **kwargs):
if self.image_url and not self.image_upload:
img_temp = NamedTemporaryFile(delete=True)
img_temp.write(urlopen(self.image_url).read())
img_temp.flush()
self.image_upload.save(f"image_{self.pk}", File(img_temp))
super(self).save(*args, **kwargs)
def __str__(self):
return self.title
HTML
{% extends "auctions/layout.html" %}
{% block body %}
<form action="" method="post" enctype="multipart/form-data">
{% csrf_token %}
{{form.as_p}}
<input type="submit" value="Submit">
</form>
{% endblock %}
URLS.PY
urlpatterns = [
path("create/", views.create_listing, name="create_listing")
]
if settings.DEBUG:
urlpatterns += static(settings.MEDIA_URL,
document_root=settings.MEDIA_ROOT)
Вам необходимо перенести изменения модели в базу данных. Это может сработать:
$ python manage.py makemigrations
$ python manage.py migrate