修改数据时,一直提示"具有 XXX 的 字典管理 已存在(即数据已存在)

原代码:

class DictConfig(models.Model):
    """
    字典表
    """
    id = models.AutoField(primary_key=True)
    dictype= models.CharField("类型", max_length=30, unique=True)
    dicdesc = models.CharField("描述", max_length=30)
    dicremarks = models.CharField("备注", max_length=50, null=True, blank=True)
    create_time = models.DateTimeField('创建时间', auto_now_add=True, null=True, blank=True)
    update_time = models.DateTimeField('更新时间', auto_now=True)

修改数据部分代码:
dic_serializer = DictConfigSerializer(data=data)
        with transaction.atomic():
            save_id = transaction.savepoint()
            if dic_serializer.is_valid():
                try:
                    dic = DictConfig.objects.get(id=id)
                    dic_serializer.update(instance=dic, validated_data=data)
                except Exception as e:
                    transaction.savepoint_rollback(save_id)
                    return JsonResponse(code=1, msg=e)

执行后一直提示该数据已存在,实际未修改任何数据,只是做了个提交操作

结果

修改代码即可:

class DictConfig(models.Model):
    """
    字典表
    """
    id = models.AutoField(primary_key=True)
    dictype= models.CharField("类型", max_length=30)  # 去掉unique=True
   dicdesc = models.CharField("描述", max_length=30) 
dicremarks
= models.CharField("备注", max_length=50, null=True, blank=True)
create_time
= models.DateTimeField('创建时间', auto_now_add=True, null=True, blank=True)
update_time
= models.DateTimeField('更新时间', auto_now=True)

 

posted @ 2022-08-25 19:34  **绵绵羊**  阅读(49)  评论(0编辑  收藏  举报