SQL异常处理

1. 问题

发现,username已经添加了唯一约束,不能重复。

2. 解决方案

通过全局异常处理器来处理。

java 复制代码
/**
 * 全局异常处理器,处理项目中抛出的业务异常
 */
@RestControllerAdvice
@Slf4j
public class GlobalExceptionHandler {  

    /**
     * 处理SQL异常
     * @param ex
     * @return
     */
    @ExceptionHandler
    public Result exceptionHandler(SQLIntegrityConstraintViolationException ex){
        //Duplicate entry 'zhangsan' for key 'employee.idx_username'
        String message = ex.getMessage();
        if(message.contains("Duplicate entry")){
            String[] split = message.split(" ");
            String username = split[2];
            String msg = username + ."已存在";
            return Result.error(msg);
        }else{
            return Result.error("未知错误");
        }
    }

}

这段代码是一个 全局异常处理器,用于捕获项目中可能抛出的 SQL 相关异常,并且对特定的错误信息进行处理和反馈给前端。在大型项目中,异常处理是非常重要的一个环节。处理异常可以提升用户体验,让用户看到更有意义的提示,而不是直接让程序崩溃或者返回不友好的错误信息。

  • @RestControllerAdvice:这是一个全局异常处理注解,能够捕获控制器中抛出的异常并进行处理。
  • @ExceptionHandler :指定了处理 SQLIntegrityConstraintViolationException 异常的方法,这个异常常见于违反数据库唯一性约束时(如插入重复数据)。
  • 异常处理逻辑
    • 通过 ex.getMessage() 获取异常的详细信息。
    • 如果异常信息包含 "Duplicate entry",说明是由于重复数据引起的。
    • 通过字符串分割提取出重复的字段值(如用户名),然后生成用户友好的提示信息(如 zhangsan已存在)。
    • 如果不是重复数据错误,返回通用的提示 "未知错误"

3. 扩展

3.1 为什么要处理异常

  • 提升用户体验:让用户看到更直观的错误提示,而不是复杂的技术信息。
  • 增强安全性:避免暴露数据库内部信息,减少安全风险。
  • 集中管理异常:通过全局异常处理器,能够在一个地方处理项目中所有的异常,避免在每个控制器方法中重复处理。

3.2 处理思路

  • 捕获异常:统一捕获数据库异常,避免程序直接崩溃。
  • 分析信息:从异常信息中提取出具体的重复字段,生成友好的提示。
  • 返回响应 :通过 Result.error() 将处理后的信息返回给前端,提升用户体验。
相关推荐
轻微的风格艾丝凡3 分钟前
嵌入式定时器计时技巧:用有符号数省略溢出判断的底层逻辑与实践
数据库·算法·dsp开发·嵌入式软件
恩创软件开发5 分钟前
创业日常2026-1-8
java·经验分享·微信小程序·小程序
想用offer打牌35 分钟前
一站式了解Spring AI Alibaba的流式输出
java·人工智能·后端
Lonely丶墨轩36 分钟前
从登录入口窥见架构:一个企业级双Token认证系统的深度拆解
java·数据库·sql
收获不止数据库1 小时前
黄仁勋2026CES演讲复盘:旧世界,裂开了!
大数据·数据库·人工智能·职场和发展
汽车仪器仪表相关领域1 小时前
工况模拟精准检测,合规减排赋能行业 ——NHASM-1 型稳态工况法汽车排气检测系统项目实战经验分享
数据库·算法·单元测试·汽车·压力测试·可用性测试
2301_800256111 小时前
数据库设计中的 “数据依赖→设计异常→关系分解(范式)” 核心逻辑
数据库·postgresql
冰冰菜的扣jio1 小时前
Redis基础数据结构
数据结构·数据库·redis
汽车仪器仪表相关领域2 小时前
光轴精准测量,安全照明保障——NHD-8101/8000型远近光检测仪项目实战分享
数据库·人工智能·安全·压力测试·可用性测试
掘根2 小时前
【仿Muduo库项目】EventLoop模块
java·开发语言