mybatis 仿写思路以及初版源码

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

_努力努力再努力_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值