Mybatis SqlSession的两种使用方式

本文详细介绍了MyBatis框架中的两种主要操作数据库的方法:直接使用SqlSession调用mapper文件的SQL语句,以及通过面向接口的方式,利用SqlSession获取mapper接口实例执行SQL语句。文中探讨了两种方式的区别,包括mapper命名空间的作用、接口与mapper文件的对应关系,以及在代码结构上的注意事项。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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的根路径就不同了,这里一定要注意。

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值