Mybatis-Mapper代理开发
-
Mapper开发的方式
-
使用Mybatis开发Dao,通常有两种方法,即原始Dao开发方法和Mapper接口开发方法
-
使用Dao开发所需要的
-
SqlSessionFactoryBuilder
SqlSessionFactory的实例可以通过SqlSessionFactoryBuilder获得,即用于创建SqlSessionFacoty,且创建完后就不再需要了
-
SqlSessionFactory
一个接口,可以从中获得SqlSession的实例,创建完后可以重复使用,通常以单例模式管理
-
SqlSession
一个面向用户的接口,通常定义了数据库操作
-
-
原始Dao开发优缺点
优点:较容易理解
缺点:需要写Dao和Dao实现,需要较多代码
-
Mapper接口开发优点
优点:开发人员只需要写Mapper接口,然后按照规范配置,然后Mybatis就会自动实现类似Dao实现,解决原生编码方式,官方推荐
-
-
Mapper代理开发的步骤
-
定义与SQL映射文件同名的Mapper接口,并且将Mapper接口和SQL映射文件放置在同一目录下
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-VilVZV53-1643021591683)(C:\Users\18752\AppData\Roaming\marktext\images\2022-01-24-09-14-12-image.png)]
-
设置SQL映射文件的namespace属性为Mapper接口全限定名
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-J7k5S6hG-1643021591684)(C:\Users\18752\AppData\Roaming\marktext\images\2022-01-24-09-16-12-image.png)]
-
在Mapper接口中定义方法,方法名技术SQL映射文件中sql语句的id,并保持参数类型和返回值类型一致
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-4hQ3Kgm3-1643021591684)(C:\Users\18752\AppData\Roaming\marktext\images\2022-01-24-09-16-30-image.png)]
-
编码
-
通过SqlSession的getMapper方法获取Mapper接口的代理对象
-
调用对应方法完成sql的执行
per方法获取Mapper接口的代理对象 -
调用对应方法完成sql的执行
-
-