DataIntegrityViolationException

DataIntegrityViolationException


这个是一个唯一约束,就是说,在表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有错误发生,但无法归类到某一更为具体的异常中

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值