获取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实现方式。