Сбой ограничения Django Not null при публикации данных json в модели - PullRequest
0 голосов
/ 26 октября 2018

эй, я попробовал этот код, но все еще есть ошибка, из-за которой нет ограничения 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;
    } );
            });

Ответы [ 2 ]

0 голосов
/ 29 октября 2018

Если вы прочитаете вторую трассировку (первая трассировка из другого представления 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

0 голосов
/ 26 октября 2018
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')

    ...
...