Автоматическое поле идентификатора, возвращающее «Нет» в Django

#python #django #django-models

Вопрос:

Я новичок в Django, пытаюсь создать программу, которая сохранит модель с некоторыми входными данными.

(В конце концов, я буду использовать форму для этого ввода, но request.POST она будет содержать то, что я хочу отправить в несколько разных мест, поэтому я не могу просто использовать ModelForm .)

Это код для модели:

 class Bid(models.Model):
    bid_owner = models.ForeignKey(User, on_delete=models.CASCADE, related_name="owner")
    bid_value = models.DecimalField(max_digits=6, decimal_places=2)
    bid_no = models.IntegerField(default=0, null = True, blank=True)
    bid_open = models.BooleanField(default=True, null = True, blank=True)
    bid_winner = models.ForeignKey(User, blank=True, default="None", null=True, on_delete=models.CASCADE, related_name="winner")

    def __str__(self):
        return f"My ID is {self.id} and this is {self.bid_owner}'s listing"
 

И это код, по которому я звоню views.py:

 def bar(request):
    foo = Bid(bid_owner = request.user, bid_value = 25)
    foo.save()
 

Но это продолжает вызывать ошибку:

Поле «идентификатор» ожидало номер, но получило «Нет».

Из документации я видел, что содержимое id поля должно автоматически генерироваться во время сохранения, поэтому я не знаю, как это решить. При рендеринге HttpResponse отображение содержимого foo всего, кажется, работает, за исключением id . Я также могу создать новый Bid просто отлично, используя администратора.

Это полная обратная связь:

 Environment:


Request Method: GET
Request URL: http://127.0.0.1:8000/createpage

Django Version: 3.2.7
Python Version: 3.9.7
Installed Applications:
['auctions',
 'django.contrib.admin',
 'django.contrib.auth',
 'django.contrib.contenttypes',
 'django.contrib.sessions',
 'django.contrib.messages',
 'django.contrib.staticfiles']
Installed Middleware:
['django.middleware.security.SecurityMiddleware',
 'django.contrib.sessions.middleware.SessionMiddleware',
 'django.middleware.common.CommonMiddleware',
 'django.middleware.csrf.CsrfViewMiddleware',
 'django.contrib.auth.middleware.AuthenticationMiddleware',
 'django.contrib.messages.middleware.MessageMiddleware',
 'django.middleware.clickjacking.XFrameOptionsMiddleware']



Traceback (most recent call last):
  File "C:UsersCasual HermitAppDataLocalProgramsPythonPython39libsite-packagesdjangodbmodelsfields__init__.py", line 1823, in get_prep_value
    return int(value)

The above exception (invalid literal for int() with base 10: 'None') was the direct cause of the following exception:
  File "C:UsersCasual HermitAppDataLocalProgramsPythonPython39libsite-packagesdjangocorehandlersexception.py", line 47, in inner
    response = get_response(request)
  File "C:UsersCasual HermitAppDataLocalProgramsPythonPython39libsite-packagesdjangocorehandlersbase.py", line 181, in _get_response
    response = wrapped_callback(request, *callback_args, **callback_kwargs)
  File "C:UsersCasual HermitDocumentscs50_webdevprojectsproject2commercecommerceauctionsviews.py", line 121, in creation_page
    foo.save()
  File "C:UsersCasual HermitAppDataLocalProgramsPythonPython39libsite-packagesdjangodbmodelsbase.py", line 726, in save
    self.save_base(using=using, force_insert=force_insert,
  File "C:UsersCasual HermitAppDataLocalProgramsPythonPython39libsite-packagesdjangodbmodelsbase.py", line 763, in save_base
    updated = self._save_table(
  File "C:UsersCasual HermitAppDataLocalProgramsPythonPython39libsite-packagesdjangodbmodelsbase.py", line 868, in _save_table
    results = self._do_insert(cls._base_manager, using, fields, returning_fields, raw)
  File "C:UsersCasual HermitAppDataLocalProgramsPythonPython39libsite-packagesdjangodbmodelsbase.py", line 906, in _do_insert
    return manager._insert(
  File "C:UsersCasual HermitAppDataLocalProgramsPythonPython39libsite-packagesdjangodbmodelsmanager.py", line 85, in manager_method
    return getattr(self.get_queryset(), name)(*args, **kwargs)
  File "C:UsersCasual HermitAppDataLocalProgramsPythonPython39libsite-packagesdjangodbmodelsquery.py", line 1270, in _insert
    return query.get_compiler(using=using).execute_sql(returning_fields)
  File "C:UsersCasual HermitAppDataLocalProgramsPythonPython39libsite-packagesdjangodbmodelssqlcompiler.py", line 1415, in execute_sql
    for sql, params in self.as_sql():
  File "C:UsersCasual HermitAppDataLocalProgramsPythonPython39libsite-packagesdjangodbmodelssqlcompiler.py", line 1358, in as_sql
    value_rows = [
  File "C:UsersCasual HermitAppDataLocalProgramsPythonPython39libsite-packagesdjangodbmodelssqlcompiler.py", line 1359, in amp;<listcompamp;>
    [self.prepare_value(field, self.pre_save_val(field, obj)) for field in fields]
  File "C:UsersCasual HermitAppDataLocalProgramsPythonPython39libsite-packagesdjangodbmodelssqlcompiler.py", line 1359, in amp;<listcompamp;>
    [self.prepare_value(field, self.pre_save_val(field, obj)) for field in fields]
  File "C:UsersCasual HermitAppDataLocalProgramsPythonPython39libsite-packagesdjangodbmodelssqlcompiler.py", line 1300, in prepare_value
    value = field.get_db_prep_save(value, connection=self.connection)
  File "C:UsersCasual HermitAppDataLocalProgramsPythonPython39libsite-packagesdjangodbmodelsfieldsrelated.py", line 971, in get_db_prep_save
    return self.target_field.get_db_prep_save(value, connection=connection)
  File "C:UsersCasual HermitAppDataLocalProgramsPythonPython39libsite-packagesdjangodbmodelsfields__init__.py", line 842, in get_db_prep_save
    return self.get_db_prep_value(value, connection=connection, prepared=False)
  File "C:UsersCasual HermitAppDataLocalProgramsPythonPython39libsite-packagesdjangodbmodelsfields__init__.py", line 2486, in get_db_prep_value
    value = self.get_prep_value(value)
  File "C:UsersCasual HermitAppDataLocalProgramsPythonPython39libsite-packagesdjangodbmodelsfields__init__.py", line 1825, in get_prep_value
    raise e.__class__(

Exception Type: ValueError at /createpage
Exception Value: Field 'id' expected a number but got 'None'.
 

Ответ №1:

Проблема в default значении в bid_winner поле.

Вы пытаетесь создать Bid запись, не передавая bid_winner ее . Поэтому при сохранении Bid объекта Django пытается заполнить bid_winner столбец его значением по умолчанию, которое является "None" .

Но Джанго рассчитывает найти id в этом что-то, потому bid_winner что есть ForeignKey .

Поэтому опустите значение по умолчанию bid_winner , чтобы исправить это. Как вы уже заявили null=True , это будет None , если вы ничего ему не передадите.

Комментарии:

1. Исправлено указанное значение по умолчанию. Обратите внимание, что default=None (хотя это и не нужно) нормально, просто default="None" нет. Кроме того, значение по умолчанию default равно None независимо от null=True .