Mapper方法的具体执行流程分析

获取Mapper对象时,会获取到一个MapperProxyFactory工厂类,并创建一个MapperProxy代理类,在执行Mapper接口的方法时,会调用MapperProxy的invoke方法。

invoke()里又是调用execute()方法执行增删改操作。

execute()方法里主要做了两件事情:

1.method.converArgsToSqlCommandParam(args):将参数转换为SQL语句中参数;

2.sqlSession.selectOne(args):通过sqlSession执行查询。

先看method.converArgsToSqlCommandParam(args):

里面调用了getNameedParams()方法,主要就是帮我们组装好了参数名称以及参数值的对应关系。

sql参数获取成功后,接下来就是执行sql语句,及返回结果,

看sqlSession.selectOne(args)方法:其实调用的还是selectList方法,然后返回list.get

(0)的数据。接下来看selectList方法,主要做了两件事::

1.获取MappedStatement对象,从之前解析好的configuration中获取,里面封装着sql语句信息。

2.通过executor执行器执行对应的sql,将参数传递进去。

继续看query方法:里面的doQuery()方法,牵扯到一二级缓存的查询,具体可以看一二级缓存的博客。里面将#{id}替换成了1,这个过程是通过StatementHandler和ParameterHandler完成的。在替换为参数之后,就到了这正与数据库交互的环节了。执行具体的查询,其实就是原生JDBC实现方式。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值