栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

IntegrityError:区分唯一约束和非空违反

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

IntegrityError:区分唯一约束和非空违反

psycopg2

SQLSTATE
作为
pgpre
成员提供了例外,它为您提供了相当细粒度的错误信息以进行匹配。

python3>>> import psycopg2>>> conn = psycopg2.connect("dbname=regress")>>> curs = conn.cursor()>>> try:...     curs.execute("INVALID;")... except Exception as ex:...     xx = ex>>> xx.pgpre'42601'

有关代码含义,请参见PostgreSQL手册中的
附录A:错误代码
。请注意,您可以在前两个字符上粗略地匹配广泛的类别。在这种情况下,我可以看到SQLSTATE42601

syntax_error
Syntax Error or Access Rule Violation
类别中。

您想要的代码是:

23505   unique_violation23502   not_null_violation

所以你可以这样写:

try:    principal = cls.objects.create(        user_id=user.id,        email=user.email,        path='something'    )except IntegrityError as ex:    if ex.pgpre == '23505':        principal = cls.objects.get( user_id=user.id, email=user.email        )    else:        raise

也就是说,这是执行

upsert
or的不好方法
merge
。@
pr0gg3d大概是建议使用Django的正确方法的正确方法。我不使用Django,所以我无法对此发表评论。有关upsert /merge的一般信息,请参阅depesz关于该主题的文章。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/645091.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号