Mybatis Plus 是如何实现动态 SQL 语句的?原理你懂吗?

本文深入解析了Mybatis Plus如何实现动态SQL语句,主要涉及MybatisConfiguration类的扩展、SqlRunnerInjector的注入以及MybatisMapperAnnotationBuilder类在动态构造SQL中的作用。通过这些机制,Mybatis Plus能够加载并注册自定义的SQL方法,实现动态脚本的功能。
摘要由CSDN通过智能技术生成

《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门,即可获取!

public class MybatisSqlSessionFactoryBuilder extends SqlSessionFactoryBuilder {

public SqlSessionFactory build(Configuration configuration) {

// … 省略若干行

if (globalConfig.isEnableSqlRunner()) {

new SqlRunnerInjector().inject(configuration);

}

// … 省略若干行

return sqlSessionFactory;

}

}

这里涉及到2个MP2个功能类

  • 扩展继承自Mybatis的MybatisConfiguration类: MP动态脚本构建,注册,及其它逻辑判断。

  • SqlRunnerInjector: MP默认插入一些动态方法的xml 脚本方法。

MybatisConfiguration类

这里我们重点剖析MybatisConfiguration类,在MybatisConfiguration中,MP初始化了其自身的MybatisMapperRegistry,而MybatisMapperRegistry是MP加载自定义的SQL方法的注册器。

MybatisConfiguration中很多方法是使

  • 19
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Mybatis-Plus 中,SQL 的解析是通过内置的 SQL 解析器来实现的。Mybatis-Plus 使用了 Mybatis 的核心组件和功能,包括 SQL 解析、参数处理、SQL 执行等。 具体的 SQL 解析流程如下: 1. Mybatis-Plus 会通过 `SqlParserUtils` 工具类创建一个 SQL 解析器对象 `SqlParser`。 2. 在执行 SQL 之前,Mybatis-Plus 会调用 `SqlParser` 的 `processSelect` 方法进行解析。该方法会解析 SQL 中的查询字段、表名、条件等信息,并返回一个 `SqlInfo` 对象。 3. `SqlInfo` 对象中包含了解析后的 SQL 语句、参数映射等信息,可以通过该对象获取解析后的 SQL 语句和参数。 4. Mybatis-Plus 将解析后的 SQL 语句和参数传递给 Mybatis 的执行引擎,通过 `SqlSession` 执行 SQL。 需要注意的是,Mybatis-Plus 的 SQL 解析器仅对内置的基本查询方法进行解析,如 `selectById`、`selectList`、`selectPage` 等。对于自定义的 SQL 语句或使用 Mybatis 的 XML 映射文件,则需要手动编写和解析 SQL。 此外,Mybatis-Plus 还提供了一些钩子函数和扩展点,可以自定义 SQL 解析和处理的逻辑。例如,可以实现 `ISqlParser` 接口来自定义 SQL 解析器,实现 `ISqlInjector` 接口来自定义 SQL 注入器等。 总结起来,Mybatis-Plus 是通过内置的 SQL 解析器来解析 SQL,然后将解析后的 SQL 语句和参数传递给 Mybatis 的执行引擎。希望能够解答你的问题!如果还有其他疑问,请继续提问。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值