mybatis 作为一款 半自动的ORM持久层框架,具有较高的SQL灵活性,了解实现原理是非常有必要的,以下是我仿写的执行步骤:
根据步骤写代码:首先创建 sqlSession,这里我没有使用工厂的设计模式来创建,直接创建了一个自写的 MySqlSession 对象
在创建好 sqlSession,开始通过动态代理获取 mapper 代理对象,
在获得代理对象以后,就可以调用 方法了,在调用方法之前,需要先执行代理:
代理对象 invoke 方法,通过循环找到当前执行的 sql 的唯一标识符 id,然后进入方法内部:
通过 statement,找到 sql 语句,下面开始执行:
运行 sql 语句,首先要获取数据库连接,首先读取 mybatisConfig.xml 拿到数据库名称和用户名密码:
开始运行 sql 语句,此方法是 select 所以首先循环遍历结果,然后将得到的结果封装到对象中最后返回
此时得到结果,完成 select 语句的框架仿写,增删改都涉及到事务的开启,因此只需要手动实现一个函数即可:
此方案只是初版,没有 cache 和 工厂代理的实现
源码地址:
https://gitee.com/tang-haoxiang/mybatis-simulate