code-learning/mybatis/06-mybatis-异常模块.md

4.9 KiB
Raw Blame History

精尽 MyBatis 源码分析 —— 异常模块

1. 概述

本文,我们来分享 MyBatis 的异常模块,对应 exceptions 包。如下图所示:exceptions 包exceptions

《精尽 MyBatis 源码解析 —— 项目结构一览》 中,简单介绍了这个模块如下:

定义了 MyBatis 专有的 PersistenceException 和 TooManyResultsException 异常。

实际上MyBatis 不仅仅在 exceptions 包下有异常,在其他包下也有异常,整体如下类图:异常体系异常体系

下面,我们逐个包的异常看过看过去。

2. exceptions

2.1 IbatisException

org.apache.ibatis.exceptions.IbatisException ,实现 RuntimeException 类IBatis 的异常基类。代码如下:

@Deprecated
public class IbatisException extends RuntimeException {

  private static final long serialVersionUID = 3880206998166270511L;

  public IbatisException() {
    super();
  }

  public IbatisException(String message) {
    super(message);
  }

  public IbatisException(String message, Throwable cause) {
    super(message, cause);
  }

  public IbatisException(Throwable cause) {
    super(cause);
  }

}
  • 实际上IbatisException 已经在 2015 年被废弃,取代它的是 PersistenceException 类。

2.2 PersistenceException

org.apache.ibatis.exceptions.PersistenceException ,继承 IbatisException 类,目前 MyBatis 真正的异常基类。代码如下:

public class PersistenceException extends IbatisException {

    private static final long serialVersionUID = -7537395265357977271L;

    public PersistenceException() {
        super();
    }

    public PersistenceException(String message) {
        super(message);
    }

    public PersistenceException(String message, Throwable cause) {
        super(message, cause);
    }

    public PersistenceException(Throwable cause) {
        super(cause);
    }
    
}

2.2.1 ExceptionFactory

org.apache.ibatis.exceptions.ExceptionFactory ,异常工厂。代码如下:

public class ExceptionFactory {

    private ExceptionFactory() {
        // Prevent Instantiation
    }

    /**
     * 包装异常成 PersistenceException
     *
     * @param message 消息
     * @param e 发生的异常
     * @return PersistenceException
     */
    public static RuntimeException wrapException(String message, Exception e) {
        return new PersistenceException(ErrorContext.instance().message(message).cause(e).toString(), e);
    }

}

2.3 TooManyResultsException

org.apache.ibatis.exceptions.TooManyResultsException ,继承 PersistenceException 类,查询返回过多结果的异常。期望返回一条,实际返回了多条。代码如下:

public class TooManyResultsException extends PersistenceException {

    private static final long serialVersionUID = 8935197089745865786L;

    public TooManyResultsException() {
        super();
    }

    public TooManyResultsException(String message) {
        super(message);
    }

    public TooManyResultsException(String message, Throwable cause) {
        super(message, cause);
    }

    public TooManyResultsException(Throwable cause) {
        super(cause);
    }

}

3. parsing

3.1 ParsingException

org.apache.ibatis.parsing.ParsingException ,继承 PersistenceException 类,解析异常。代码如下:

public class ParsingException extends PersistenceException {

    private static final long serialVersionUID = -176685891441325943L;

    public ParsingException() {
        super();
    }

    public ParsingException(String message) {
        super(message);
    }

    public ParsingException(String message, Throwable cause) {
        super(message, cause);
    }

    public ParsingException(Throwable cause) {
        super(cause);
    }

}

3. 其它包

实际上,我们会看到其他包,会和 parsing 包一样,都会定义其独有的异常类。但是,代码都是相同的。所以,这里就简单整理如下:

  • reflectionReflectionException
  • loggingLogException
  • builderBuilderException、IncompleteElementException
  • scriptingScriptingException
  • bindingBindingException
  • typeTypeException
  • sessionSqlSessionException
  • cacheCacheException
  • transactionTransactionException
  • datasourceDataSourceException
  • executorResultMapException、ExecutorException、BatchExecutorException
  • pluginPluginException

666. 彩蛋

哈哈哈,因为 《精尽 MyBatis 源码分析 —— 反射模块》 一文让我们都很累,所以这篇文章,给我们度假下。哈哈哈。