员工重复添加问题,数据库限制异常SQLIntegrityConstraintViolationException,添加全局异常处理器

当尝试新增用户名为laowang的记录时,由于employee表中username字段存在唯一约束,导致操作失败。异常信息揭示了冲突的键值。解决方案是通过全局异常处理器@ExceptionHandler捕获SQLIntegrityConstraintViolationException,解析异常消息并返回用户友好的“已存在”错误提示。
摘要由CSDN通过智能技术生成

问题复现

新增laowang的用户,若employee表中之前已存在,那么执行会报错

 

后台异常

 

问题分析

查看数据库employee表发现username设置了约束

 

解决方案

通过异常处理器进行统一处理GlobalExceptionHandler

 @ExceptionHandler(SQLIntegrityConstraintViolationException.class)
 public Result handleSQLIntegrityConstraintViolationException(SQLIntegrityConstraintViolationException ex){
     // 异常的具体信息  Duplicate entry 'laohei' for key 'idx_username'
     // 根据内容找到
     String exMsg = ex.getMessage();
     String info =  exMsg.split(" ")[2];
     return Result.error(info+" "+ MessageConstant.RESULT_EXISTS);
 }

在常量类中定义常量 MessageConstant.RESULT_EXISTS

 public static final String RESULT_EXISTS = "已存在";

注意使用的时候添加相关注解

@RestControllerAdvice
@ExceptionHandler(SQLIntegrityConstraintViolationException.class)

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值