Mybatis源码解析 —— Sql解析详解

引言

Java Server理解与实践 ——Spring集成Mybatis中,笔者简要地介绍了Mybatis框架。

Mybatis框架极大地简化了ORM,让使用者自定义sql语句,再将查询结果映射到Java类中,其中很关键的一部分就是,将用户写的sql语句(以xml或者注解形式)解析成数据库可执行的sql语句。

本文将会介绍这整个的解析过程。

Sql解析架构

本文将以一下的注解定义为例,剖析整个解析过程。

@Select({
  "<script>",
            "SELECT account",
            "FROM user",
            "WHERE id IN",
            "<foreach item='item' index='index' collection='list'",
            "open='(' separator=',' close=')'>",
            "#{item}",
            "</foreach>",
            "</script>"})
    List<String> selectAccountsByIds(@Param("list") int[] ids);

Sql解析其实分成了两部分,第一部分是将注解/xml中定义的sql语句转化成内存中的MappedStatement,也就是将script部分转化成内存中的MappedStatement,这部分发生在Mybatis初始化的时候,第二部分则是根据MappedStatement以及传入的参数,生成可以直接执行的sql语句,这部分发生在mapper函数被调用的时候。

从注解/xml 定义到MappedStatement

首先,我们要明白什么是MappedStatement,先来看看MappedStatment的类定义。

public final class MappedStatement {
   

  private String resource; //来源,一般为文件名或者是注解的类名
  private Configuration configuration; //Mybatis的全局唯一Configuration
  private String id; //标志符,可以用于缓存
  private Integer fetchSize; //每次需要查询的行数(可选)
  private Integer timeout;
  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值