修改数据时,一直提示"具有 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 @   **绵绵羊**  阅读(57)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
· 三行代码完成国际化适配,妙~啊~
点击右上角即可分享
微信分享提示