加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

如何捕获错误1062“重复条目”独立于使用的数据库/引擎?

发布时间:2020-12-12 06:37:57 所属栏目:MsSql教程 来源:网络整理
导读:在一个项目中,我开始使用 MySQL作为数据库.而不是先检查,我只是做一个插入,如果我得到代码1062的IntegrityError异常,我知道有一个重复的条目并警告用户,这样做. 看起来基本上是这样的: try: # add duplicate,nothing bad happens yet,is only in sqla sessio
在一个项目中,我开始使用 MySQL作为数据库.而不是先检查,我只是做一个插入,如果我得到代码1062的IntegrityError异常,我知道有一个重复的条目并警告用户,这样做.

看起来基本上是这样的:

try:
    # add duplicate,nothing bad happens yet,is only in sqla session
    db.session.add(User(email='already_used_email@address_that_has_to_be_unique.com'))
    # commit,now the IntegrityError is raised,when sqla inserts
    db.session.commit()
except IntegrityError as e:
    db.session.rollback()
    # this is what i do with mysql,check the exception for code 1062
    # how can i replace this with something db independent?
    code,msg = e.orig
    if code == 1062:
        # send warning
        pass

现在,对于一个,这使得已经无法用例如测试.内存中的sqlite.不好,但我可以忍受.

然而,第二,我可能(必须/希望其他超出此问题的范围)切换到Postgres.当然我可以更改代码(也)检查Postgres错误代码,但我希望有一种方法让SQLALchemy告诉我,重复发生独立于数据库.数据库方言抽象……?

解决方法

您要搜索的内容称为“SQLSTATE” – 一组标准错误代码,涵盖了大多数常见的RDBMS错误状态.但它们并不一定能为所有目的提供足够的细节,我不知道sqlite是否支持它们.

> http://www.postgresql.org/docs/9.1/static/errcodes-appendix.html
> http://dev.mysql.com/doc/refman/5.0/en/error-handling.html

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读