Ошибка ограничения django not null при публикации данных json в модели

эй, я пробовал этот код, но у меня все еще есть ошибка, связанная с ограничением Not Null, я знаю, что это из-за моего уникального типа cheque_no, но как я могу удалить эту ошибку? Я не удалил мой cheque_no уникален, потому что он требуется. теперь я получаю эта проблема я хочу сохранить эти записи в моей модели.

views.py

@csrf_exempt            
def jsdata(request):
        table_data = json.loads(request.POST.get('MyData'))
        # print(table_data)
        r_data = {
            'success': True,
        }
        for data in table_data:
            # Since you are just creating objects you don't need to save created object in a variable.
                Mvouchar.objects.create(bill_no = data['BillNo'], bill_details=data['BillDetails'],am=data['Amount'])
               # r_data['success'] = False

        # IMO Views responding to ajax requests should send JsonResponse
        if r_data['success']:
            r_data['msg'] = 'Data Saved'
        else:
            r_data['msg'] = 'Not all Data Saved'
        return JsonResponse(r_data)

models.py

class Mvouchar(models.Model):
    related = models.ForeignKey(Signs, on_delete=models.CASCADE, null=True, blank=True)
    bill_no = models.CharField(max_length=8000, null=True, blank=True)
    bill_details = models.CharField(max_length=10000, null=True, blank=True)
    am = models.CharField(max_length=30000, null=True, blank=True)
    cheque_no = models.PositiveIntegerField(validators=[MaxValueValidator(6)], unique=True, help_text='integers only')
    def __str__(self):
      if self.related:
        return self.related.relation.username.title()
      else:
        return 'no related!'
    class Meta:
        verbose_name_plural = "Single Cheque Multiple Vouchar Of Users"

javascript

$("#btnjson").click(function () {
            var array1 = [];
                    $("tbody tr").each(function () {
                        var firstTableData = {};
                        firstTableData.BillNo = $(this).find('td').eq(0).text();
                        firstTableData.BillDetails = $(this).find('td').eq(1).text();
                        firstTableData.Amount = $(this).find('td').eq(2).text();
                        array1.push(firstTableData);
                    //}
                }); 
                alert(JSON.stringify(array1));
                 $.ajax({
                type: "POST",
                url: "/jsondata/",
                dataType: 'json',
                data: {MyData: JSON.stringify(array1)},
                success: function(msg){
                alert(msg);
            }
        });
        return false;
    } );
            });

эта ошибка возникает из-за того, что check_no получает значение Null из внешнего интерфейса cheque_no = models.PositiveIntegerField (validators = [MaxValueValidator (6) ‌], unique = True, help_text = 'integer only', null = True) используйте этот код в модели .py

Ravi Bhushan 26.10.2018 07:24

эй, ошибка удаления, но что-то утомляет

monika choudhary 26.10.2018 07:32

означает, что значение bill_no bill_details и сумма сохраняются в поле not_related и сколько записей записано, а затем поле not_related создается соответственно

monika choudhary 26.10.2018 07:34

и запись не попадает в модель, представленную в полной форме

monika choudhary 26.10.2018 07:35

пожалуйста, проверьте изображения, что происходит

monika choudhary 26.10.2018 07:46

Добавьте null = True в свой cheque_no. Измените ул. на self.related.relation.username.title. Если ваш заголовок не равен нулю, тогда нет необходимости добавлять, если вообще, вы можете напрямую добавить return.

Bidhan Majhi 26.10.2018 08:44

эй, угадайте, в чем проблема, слышите

monika choudhary 27.10.2018 09:07

Пожалуйста, не размещайте изображения текста в вопросах. Включите в вопрос фактический текст. Как спросить

Håken Lid 29.10.2018 11:04
0
8
282
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Ответ принят как подходящий
from django.core.validators import RegexValidator

CHEQUE_REGEX = RegexValidator( 
    regex=r'^\d{6}$', 
    message="Cheque Number must be exactly 6 digits" 
)

class Mvouchar(models.Model):
    ...

    cheque_no = models.CharField(validators=[CHEQUE_REGEX, ], unique=True, max_length=6, help_text='integers only')

    ...

Если вы прочитаете вторую трассировку (первая трассировка относится к другому представлению views.mvoucha, и вы не включили этот код в вопрос), вы обнаружите, что проблема заключается в этой строке в вашей функции просмотра.

    table_data = json.loads(request.POST.get('MyData'))

Что происходит, так это то, что request.POST.get('MyData') возвращает None, который не может быть представлен как json. Вот почему кодировщик json вызывает ошибку TypeError.

Словарь request.POST используется с данными формы. Если вы хотите проанализировать полезную нагрузку json, вам нужно вместо этого использовать request.body. Например так:

    table_data = json.loads(request.body).get('MyData')

https://docs.djangoproject.com/en/2.1/ref/request-response/#django.http.HttpRequest.POST

Другие вопросы по теме