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
也就是说,这是执行
upsertor的不好方法
merge。@
pr0gg3d大概是建议使用Django的正确方法的正确方法。我不使用Django,所以我无法对此发表评论。有关upsert /merge的一般信息,请参阅depesz关于该主题的文章。



