Return Database.Cursor.execute(self, query, params)django.db.utils.OperationalError: no such column

Я знаю, что перед запуском сервера я должен сделать makemigrations, но я не могу, я не знаю так много python и django я не могу мигрировать или makemigrations или runserver я пробовал указанные для основного приложения, но все еще дают мне ту же ошибку я написал это 2 раза ничего не изменилось я пытаюсь сделать трекер цен для себя, когда я пытаюсь makemigrations или runserver дают мне эту ошибку ;

вот мой views.py ;

@login_required
def search(request):
    if request.method == "POST":
        item_url = request.POST.get("searchbox")
        maximum_price = int(request.POST.get("max_price"))
        if item_url != "" and maximum_price != "":
            user = request.user
            item_model = Item(user=user, url = item_url, max_price = maximum_price)
            item_model.save()
            return redirect('search')

    return render(request, 'main_app/search.html')




def search_price():
    max_price = 170
    hdr= {'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/98.0.4758.109 Safari/537.36 OPR/84.0.4316.50'}
    
    for element in Item.objects.all():
        if element.status == False:
            user = element.user
            user_email = user.email
            item_url = element.url
            max_price = element.max_price

            url = requests.get(str(item_url), headers=hdr)

            soup = BeautifulSoup(url.content, 'html.parser')
            price_span= soup.find('span', class_="price-current__amount").text[:3].split(',')
            price =int("".join(price_span))
            
            if price <= max_price:
                subject = 'Ürününüz İndirime GİRDİ!!!'
                message = f"Merhaba {user.username}, takip ettiğiniz ürün{item_url}, ayarladığınız fiyata geldi {price}"
                email_from = settings.EMAIL_HOST_USER
                recipient_list = [user_email]
                send_mail(subject,message,email_from,recipient_list)
                element.status = True
                element.save()

search_price()

и это мой model.py ;

class Item(models.Model):
    user = models.ForeignKey(User, on_delete=models.CASCADE)
    url = models.CharField(max_length=700)
    max_price = models.IntegerField()
    status = models.BooleanField(default=False)

Пожалуйста, закомментируйте или удалите search_price() и попробуйте снова создать файлы миграции. Поскольку вы вызываете эту функцию на вашем модуле, и поскольку Django инстанцирует этот модуль, он всегда будет проходить через эту функцию, и поскольку еще нет никакого столбца состояния, он не может создать ваш файл миграции, потому что он не работает в этом модуле.

Измените эту часть:

def search_price():
    max_price = 170
    hdr= {'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/98.0.4758.109 Safari/537.36 OPR/84.0.4316.50'}
    
    for element in Item.objects.all():
        if element.status == False:
            user = element.user
            user_email = user.email
            item_url = element.url
            max_price = element.max_price

            url = requests.get(str(item_url), headers=hdr)

            soup = BeautifulSoup(url.content, 'html.parser')
            price_span= soup.find('span', class_="price-current__amount").text[:3].split(',')
            price =int("".join(price_span))
            
            if price <= max_price:
                subject = 'Ürününüz İndirime GİRDİ!!!'
                message = f"Merhaba {user.username}, takip ettiğiniz ürün{item_url}, ayarladığınız fiyata geldi {price}"
                email_from = settings.EMAIL_HOST_USER
                recipient_list = [user_email]
                send_mail(subject,message,email_from,recipient_list)
                element.status = True
                element.save()

search_price()

to:

def search_price():
    max_price = 170
    hdr= {'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/98.0.4758.109 Safari/537.36 OPR/84.0.4316.50'}
    
    for element in Item.objects.all():
        if element.status == False:
            user = element.user
            user_email = user.email
            item_url = element.url
            max_price = element.max_price

            url = requests.get(str(item_url), headers=hdr)

            soup = BeautifulSoup(url.content, 'html.parser')
            price_span= soup.find('span', class_="price-current__amount").text[:3].split(',')
            price =int("".join(price_span))
            
            if price <= max_price:
                subject = 'Ürününüz İndirime GİRDİ!!!'
                message = f"Merhaba {user.username}, takip ettiğiniz ürün{item_url}, ayarladığınız fiyata geldi {price}"
                email_from = settings.EMAIL_HOST_USER
                recipient_list = [user_email]
                send_mail(subject,message,email_from,recipient_list)
                element.status = True
                element.save()

# search_price()  --> here you are calling this function which is the
# main reason of your error. So this line should be removed.
Вернуться на верх