DataIntegrityViolationException

来源:互联网 发布:寂寞聊天软件 编辑:程序博客网 时间:2024/06/07 04:03

今天写代码的时候,突然发现有一个地方很是诧异,就是有人居然在Dao进行操作的时候,捕获异常,这让我感到十分的诧异,

 try {            personDAO.addAdvertiser(person);        } catch(DataIntegrityViolationException e) {            logger.error("person DataIntegrityViolationException", e);
}

这是一个很普通的一个往数据里面的添加操作,添加过程就不用写了,就是很普通的@Sql传参数的格式,但是就是不知道,为什么就会抛错,然后,今天查看了一个数据库的里面的表的结构,这个是


这个是一个唯一约束,就是说,在表mytest1,在添加还是修改的时候,以(name,value)同是作为key,不能相同,如果相同的,或数据库就会抛错,说你违反了唯一性约束,此时如果我们捕获这个异常,就可以做一些操作,返回一些值,什么的。这样就不需要我们把值拿出来进行判断了,

另外附上Spring的DAO的异常层次:



异常

何时抛出

CleanupFailureDataAccessException一项操作成功地执行,但在释放数据库资源时发生异常(例如,关闭一个Connection)DataAccessResourceFailureException数据访问资源彻底失败,例如不能连接数据库DataIntegrityViolationExceptionInsert或Update数据时违反了完整性,例如违反了惟一性限制DataRetrievalFailureException某些数据不能被检测到,例如不能通过关键字找到一条记录DeadlockLoserDataAccessException当前的操作因为死锁而失败IncorrectUpdateSemanticsDataAccessExceptionUpdate时发生某些没有预料到的情况,例如更改超过预期的记录数。当这个异常被抛出时,执行着的事务不会被回滚InvalidDataAccessApiusageException一个数据访问的JAVA API没有正确使用,例如必须在执行前编译好的查询编译失败了invalidDataAccessResourceUsageException错误使用数据访问资源,例如用错误的SQL语法访问关系型数据库OptimisticLockingFailureException乐观锁的失败。这将由ORM工具或用户的DAO实现抛出TypemismatchDataAccessExceptionJava类型和数据类型不匹配,例如试图把String类型插入到数据库的数值型字段中UncategorizedDataAccessException有错误发生,但无法归类到某一更为具体的异常中

异常

何时抛出

CleanupFailureDataAccessException一项操作成功地执行,但在释放数据库资源时发生异常(例如,关闭一个Connection)DataAccessResourceFailureException数据访问资源彻底失败,例如不能连接数据库DataIntegrityViolationExceptionInsert或Update数据时违反了完整性,例如违反了惟一性限制DataRetrievalFailureException某些数据不能被检测到,例如不能通过关键字找到一条记录DeadlockLoserDataAccessException当前的操作因为死锁而失败IncorrectUpdateSemanticsDataAccessExceptionUpdate时发生某些没有预料到的情况,例如更改超过预期的记录数。当这个异常被抛出时,执行着的事务不会被回滚InvalidDataAccessApiusageException一个数据访问的JAVA API没有正确使用,例如必须在执行前编译好的查询编译失败了invalidDataAccessResourceUsageException错误使用数据访问资源,例如用错误的SQL语法访问关系型数据库OptimisticLockingFailureException乐观锁的失败。这将由ORM工具或用户的DAO实现抛出TypemismatchDataAccessExceptionJava类型和数据类型不匹配,例如试图把String类型插入到数据库的数值型字段中UncategorizedDataAccessException有错误发生,但无法归类到某一更为具体的异常中
阅读全文
0 0
原创粉丝点击