Django插入错误导致重复的错误 - python

我试图将一些数据添加到Django制成的表中。

这是我的代码:

class Prefixe(models.Model):
    remote_as = models.CharField(max_length=250)
    prefix_list = models.CharField(max_length=250, unique=True)


def insert():
    p = Prefixe(remote_as='Apress', prefix_list='Berkeley')
    p.save()

我正在使用ORM创建记录,但记录失败,出现“重复”异常(请参见prefix_list定义中的unique选项)。

但是有一种方法可以避免这种异常,如果我使用特定的PG选项将insert作为原始SQL进行插入:

INSERT INTO "peer_table" ("remote_as","prefix_list")
VALUES('{}','{}')
ON CONFLICT DO NOTHING

通过ORM工作时,是否可以避免由重复导致的异常?

参考方案

您的代码可以受益于方法.get_or_create()的使用:

def insert(remote_as, prefix_list):
    p, was_created = Prefixe.objects.get_or_create(
        remote_as=remote_as, prefix_list=prefix_list)

    if was_create:
        print('a new instance was created.')
    else:
        print('the instance already exists.')

在返回'Response'(Python)中传递多个参数 - python

我在Angular工作,正在使用Http请求和响应。是否可以在“响应”中发送多个参数。角度文件:this.http.get("api/agent/applicationaware").subscribe((data:any)... python文件:def get(request): ... return Response(seriali…

Python exchangelib在子文件夹中读取邮件 - python

我想从Outlook邮箱的子文件夹中读取邮件。Inbox ├──myfolder 我可以使用account.inbox.all()阅读收件箱,但我想阅读myfolder中的邮件我尝试了此页面folder部分中的内容,但无法正确完成https://pypi.python.org/pypi/exchangelib/ 参考方案 您需要首先掌握Folder的myfo…

Python GPU资源利用 - python

我有一个Python脚本在某些深度学习模型上运行推理。有什么办法可以找出GPU资源的利用率水平?例如,使用着色器,float16乘法器等。我似乎在网上找不到太多有关这些GPU资源的文档。谢谢! 参考方案 您可以尝试在像Renderdoc这样的GPU分析器中运行pyxthon应用程序。它将分析您的跑步情况。您将能够获得有关已使用资源,已用缓冲区,不同渲染状态上…

R'relaimpo'软件包的Python端口 - python

我需要计算Lindeman-Merenda-Gold(LMG)分数,以进行回归分析。我发现R语言的relaimpo包下有该文件。不幸的是,我对R没有任何经验。我检查了互联网,但找不到。这个程序包有python端口吗?如果不存在,是否可以通过python使用该包? python参考方案 最近,我遇到了pingouin库。

django-simple-history,在admin中显示更改的字段 - python

当我从admin.ModelAdmin继承时,在管理页面的历史记录中,我可以看到哪些字段已更改。但是,现在我需要使用django-simple-history来跟踪所有模型更改。现在,对于管理员,我继承了simple_history.SimpleHistoryAdmin。我可以看到所有模型更改并还原它们,但看不到更改了哪些字段。是否可以在SimpleHist…