mybatis dao提供两种方案继承接口和mapper.xml (mybatis本身是半orm框架)
sqlSessionDaoSupport本身就是为了给用户提供dao方案而存在抽象类。它继承了Daosupport,重写了checkConfig方法(提供校验是否有sqlSessionTemplate)
我们做Dao时,需实现类继承SqlSeesionDaoSupport,使用该类提供的sqlSessionTemplate获取SqlSession。(sqlSessionFactory也是由SqlSessionTemplate提供)
SqlSession里提供一个getMapper方法,返回所代理对象,使用该对象进行操作方便快速。
如果不用该方法也可以使用sqlSession.selectOne()。但SqlSession里的SelectOne提供两种方法,这两种方法均需要指定statementId.所以还是代理好用,但是代理需要手动初始化。
4.1 代理方法
代理方法首先需要一个mapper。sqlSession完全代理了该statement,再使用的时候就无需再指定。
注意:但在SqlSessionDaoSupport里,sqlSessionTemplate未被引入。所以我们重新引入SqlSessionTemplate.
但是这个方案则需要每次都引用一次。为了方便可以提出一个baseDao,然后使用泛型载入。
注:要写Mapper.xml文件 需要sqlMapConfig.xml中进行配置
<mappers>
<mapper resource="XX.xml文件地址" />
</mappers>
另:myBatisPlus dao只要继承BaseMapper<T>即可。
mybatisPlus 源码
在mybatisSqlSessionFactoryBean中,SqlSessionFactory getObject()方法中,去看,它完成了一个自动装配的过程。它扫描了本地所有的Mapper,把所有Mapper全部初始化到了SqlSessionFactory里了。所以使用的时候,只需要传入它的T,就能对应创建出该对应的SqlSession。所以直接用即可。
其实思路一样,只是在于,一个手动一个自动。