Python DRF POST提供非空约束失败

Python DRF POST提供非空约束失败,python,django,sqlite,rest,django-rest-framework,Python,Django,Sqlite,Rest,Django Rest Framework,在Python3.9、Django3.1.2和DRF3.12.1的简单API中,获得了以下模型 class Movie(models.Model): movieNumber=models.CharField(max_length=10) movieCategory=models.CharField(max_length=20) class MovieWatcher(models.Model): firstName = models.CharField(max_lengt

在Python3.9、Django3.1.2和DRF3.12.1的简单API中,获得了以下模型

class Movie(models.Model):
    movieNumber=models.CharField(max_length=10)
    movieCategory=models.CharField(max_length=20)

class MovieWatcher(models.Model):
    firstName = models.CharField(max_length=20)
    lastName = models.CharField(max_length=20)
    middleName = models.CharField(max_length=20)
    email = models.CharField(max_length=20)
    phone = models.CharField(max_length=10)

class Reservation(models.Model): # This model has the relation with the other two.
    movie = models.ForeignKey(Movie,on_delete=models.CASCADE) # CASCADE means that when a Movie is deleted, this reservation must also be deleted.
    movieWatcher = models.OneToOneField(MovieWatcher,on_delete=models.CASCADE)
以下是FBV

@api_view(['POST'])
def save_reservation(request):
    movie=Movie.objects.get(id=request.data['movieId'])
    
    movie_watcher=MovieWatcher()
    movie_watcher.firstName=request.data['firstName']
    movie_watcher.lastName=request.data['lastName']
    movie_watcher.middleName=request.data['middleName']
    movie_watcher.email=request.data['email']
    movie_watcher.phone=request.data['phone']
    movie_watcher.save()

    reservation=Reservation()
    reservation.movie = movie
    reservation.movie_watcher = movie_watcher
    reservation.save()
    return Response(status=status.HTTP_201_CREATED)
为了测试该端点,我创建了一个POST请求http://localhost:8000/saveReservation/

之后,在体内点击。在主体内部,x-www-form-urlencoded

在这里,我使用的键是:电影ID、名字、姓氏、中间名、电子邮件和电话。作为movieId的值,我添加了一个先前创建的现有movieId,但用户不存在

从各方面考虑,我希望获得201的地位

然而,我得到一个状态为500的内部服务器错误和以下错误

完整性错误/保存保留/ 非空约束失败:movieApp\u reservation.movieWatcher\u id

在终端可以看到这个

Internal Server Error: /saveReservation/
Traceback (most recent call last):
  File "C:\Users\tiago\Desktop\beyond\venv\lib\site-packages\django\db\backends\utils.py", line 84, in _execute
    return self.cursor.execute(sql, params)
  File "C:\Users\tiago\Desktop\beyond\venv\lib\site-packages\django\db\backends\sqlite3\base.py", line 413, in execute
    return Database.Cursor.execute(self, query, params)
sqlite3.IntegrityError: NOT NULL constraint failed: movieApp_reservation.movieWatcher_id

The above exception was the direct cause of the following exception:

Traceback (most recent call last):
  File "C:\Users\tiago\Desktop\beyond\venv\lib\site-packages\django\core\handlers\exception.py", line 47, in inner
    response = get_response(request)
  File "C:\Users\tiago\Desktop\beyond\venv\lib\site-packages\django\core\handlers\base.py", line 179, in _get_response
    response = wrapped_callback(request, *callback_args, **callback_kwargs)
  File "C:\Users\tiago\Desktop\beyond\venv\lib\site-packages\django\views\decorators\csrf.py", line 54, in wrapped_view
    return view_func(*args, **kwargs)
  File "C:\Users\tiago\Desktop\beyond\venv\lib\site-packages\django\views\generic\base.py", line 70, in view
    return self.dispatch(request, *args, **kwargs)
  File "C:\Users\tiago\Desktop\beyond\venv\lib\site-packages\rest_framework\views.py", line 509, in dispatch
    response = self.handle_exception(exc)
  File "C:\Users\tiago\Desktop\beyond\venv\lib\site-packages\rest_framework\views.py", line 469, in handle_exception
    self.raise_uncaught_exception(exc)
  File "C:\Users\tiago\Desktop\beyond\venv\lib\site-packages\rest_framework\views.py", line 480, in raise_uncaught_exception
    raise exc
  File "C:\Users\tiago\Desktop\beyond\venv\lib\site-packages\rest_framework\views.py", line 506, in dispatch
    response = handler(request, *args, **kwargs)
  File "C:\Users\tiago\Desktop\beyond\venv\lib\site-packages\rest_framework\decorators.py", line 50, in handler
    return func(*args, **kwargs)
  File "C:\Users\tiago\Desktop\beyond\beyond\beyondMoviesAPI\movieApp\views.py", line 33, in save_reservation
    reservation.save()
  File "C:\Users\tiago\Desktop\beyond\venv\lib\site-packages\django\db\models\base.py", line 753, in save
    self.save_base(using=using, force_insert=force_insert,
  File "C:\Users\tiago\Desktop\beyond\venv\lib\site-packages\django\db\models\base.py", line 790, in save_base
    updated = self._save_table(
  File "C:\Users\tiago\Desktop\beyond\venv\lib\site-packages\django\db\models\base.py", line 895, in _save_table
    results = self._do_insert(cls._base_manager, using, fields, returning_fields, raw)
  File "C:\Users\tiago\Desktop\beyond\venv\lib\site-packages\django\db\models\base.py", line 933, in _do_insert
    return manager._insert(
  File "C:\Users\tiago\Desktop\beyond\venv\lib\site-packages\django\db\models\manager.py", line 85, in manager_method
    return getattr(self.get_queryset(), name)(*args, **kwargs)
  File "C:\Users\tiago\Desktop\beyond\venv\lib\site-packages\django\db\models\query.py", line 1254, in _insert
    return query.get_compiler(using=using).execute_sql(returning_fields)
  File "C:\Users\tiago\Desktop\beyond\venv\lib\site-packages\django\db\models\sql\compiler.py", line 1397, in execute_sql
    cursor.execute(sql, params)
  File "C:\Users\tiago\Desktop\beyond\venv\lib\site-packages\django\db\backends\utils.py", line 98, in execute
    return super().execute(sql, params)
  File "C:\Users\tiago\Desktop\beyond\venv\lib\site-packages\django\db\backends\utils.py", line 66, in execute
    return self._execute_with_wrappers(sql, params, many=False, executor=self._execute)
  File "C:\Users\tiago\Desktop\beyond\venv\lib\site-packages\django\db\backends\utils.py", line 75, in _execute_with_wrappers
    return executor(sql, params, many, context)
  File "C:\Users\tiago\Desktop\beyond\venv\lib\site-packages\django\db\backends\utils.py", line 84, in _execute
    return self.cursor.execute(sql, params)
  File "C:\Users\tiago\Desktop\beyond\venv\lib\site-packages\django\db\utils.py", line 90, in __exit__
    raise dj_exc_value.with_traceback(traceback) from exc_value
  File "C:\Users\tiago\Desktop\beyond\venv\lib\site-packages\django\db\backends\utils.py", line 84, in _execute
    return self.cursor.execute(sql, params)
  File "C:\Users\tiago\Desktop\beyond\venv\lib\site-packages\django\db\backends\sqlite3\base.py", line 413, in execute
    return Database.Cursor.execute(self, query, params)
django.db.utils.IntegrityError: NOT NULL constraint failed: movieApp_reservation.movieWatcher_id
[16/Oct/2020 18:51:00] "POST /saveReservation/ HTTP/1.1" 500 175219
将应用所有迁移

您有一个打字错误

reservation.movie\u watcher=movie\u watcher
更改为
reservation.movieWatcher=movie\u watcher

模型的字段称为
movieWatcher
,而不是
movie\u watcher

正如您在下一张图片中看到的那样,它正在工作