django .db.utils.IntegrityError: Сбой ограничения NOT NULL: home_post.author_id - PullRequest
0 голосов
/ 24 марта 2020

Я создал форму для публикации с использованием Ajax, однако, когда я нажимаю на кнопку отправки, я получаю сообщение об ошибке:

django.db.utils.IntegrityError: NOT NULL constraint failed: home_post.author_id

Я не знаю, что это такое, как раньше, у меня было отдельный html для создания сообщений, но после использования Ajax я получаю эту ошибку.

Это моя модель сообщения:

class Post(models.Model):
    title = models.CharField(max_length=100)
    content = models.TextField(validators=[MaxLengthValidator(250)])
    author = models.ForeignKey(Profile, on_delete=models.CASCADE)
    date_posted = models.DateTimeField(auto_now_add=True)
    last_edited= models.DateTimeField(auto_now=True)
    likes= models.ManyToManyField(Profile, blank=True, related_name='post_likes')

Это моя форма сообщения:

class PostForm(forms.ModelForm):
    class Meta:
        model = Post
        fields = ('title','content',)

Это мое представление create_post:

@login_required
def post_create(request):
    data = dict()
    if request.method == 'POST':
        form = PostForm(request.POST)
        if form.is_valid():      
            form.save()
            data['form_is_valid'] = True
            posts = Post.objects.all()
            data['posts'] = render_to_string('home/homepage/home.html',{'posts':posts})
        else:
            data['form_is_valid'] = False
    else:
        form = PostForm       
    context = {
    'form':form
    }
    data['html_form'] = render_to_string('home/posts/post_create.html',context,request=request)
    return JsonResponse(data) 

Это мой Ajax Javascript код:

$(document).ready(function(){
    var ShowForm = function(){
        var btn = $(this);
        $.ajax({
            url: btn.attr("data-url"),
            type: 'get',
            dataType:'json',
            beforeSend: function(){
                $('#modal-post').modal('show');
            },
            success: function(data){
                $('#modal-post .modal-content').html(data.html_form);
            }
        });
    };

    var SaveForm =  function(){
        var form = $(this);
        $.ajax({
            url: form.attr('data-url'),
            data: form.serialize(),
            type: form.attr('method'),
            dataType: 'json',
            success: function(data){
                if(data.form_is_valid){
                    $('#post-list div').html(data.posts);
                    $('#modal-post').modal('hide');
                } else {
                    $('#modal-post .modal-content').html(data.html_form)
                }
            }
        })
        return false;
    }

//create
$('.create-post-btn').click(ShowForm);
$('#modal-post').on("submit",".post-create-form",SaveForm)

//update
$('#post-list').on("click",".show-form-update",ShowForm);
$('#modal-post').on("submit",".update-form",SaveForm)

//delete
$('#post-list').on("click",".show-form-delete",ShowForm);
$('#modal-post').on("submit",".delete-form",SaveForm)
});

Я не знаю, что вызывает эту ошибку, так как мне все кажется правильным.

1 Ответ

1 голос
/ 24 марта 2020

В модели Post автор не равен нулю. Но с точки зрения, вы не установили автора до сохранения формы.

Вы можете добавить существующий идентификатор автора для публикации в представлении.

post = form.save(False)
post.author = author_id
post.save()
...