DataIntegrityViolationException

今天写代码的时候,突然发现有一个地方很是诧异,就是有人居然在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有错误发生,但无法归类到某一更为具体的异常中
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值