Mybatis SqlSession的两种使用方式

Mybatis SqlSession的两种使用方式

一,SqlSession.SelectOne(mapper+selectid)/SqlSession.SelectList(mapper+selectid)/SqlSession.SelectMap(mapper+selectid)

SqlSession直接调用mapper文件的SQL语句,不需要接口以及接口的实现类,就可以实现对数据库的操作。这种方式中,Mapper的命名空间属性的作用就是区分不同的mapper,保证mapper的唯一性。

 

二,SqlSession.getMapper(xxxMaper.class).getXXXList()

面向接口的编程方式,需要接口名与mapper的命名空间属性值保持一致,从而将接口与mapper文件对应起来。当namespace绑定某一接口之后,可以不用写该接口的实现类,MyBatis会通过接口的完整限定名查找到对应的mapper配置来执行SQL语句。因此namespace的命名必须跟接口同名。

这里由于路径设置两种思路的不同,常常会引起一些路径名上问题。

一种思路是,Mapper文件和接口同属于DAO层,故在代码结构上,Mapper文件与该DAO接口应放置在同一package下,并且习惯上都已Mapper结尾。

还有一种思路是,把Mapper.xml文件看作配置文件,而放在resoures的目录下。如此Mapper.class与Mapper.xml的根路径就不同了,这里一定要注意。

 

 

 

你可能感兴趣的:(Mybatis SqlSession的两种使用方式)