Mybatis Mapper动态代理方法 即 只写Dao接口 不写Dao的实现类

Mapper动态代理方法:程序员只需要写dao接口(Mapper),而不需要写dao实现类,由mybatis根据dao接口和映射文件中statement的定义生成接口实现代理对象。可以调用代理对象方法。  
  
Mybatis官方建议:将dao接口叫做mapper。  
  
  
目标:通过一些规则让mybatis根据dao接口和映射文件中statement的定义生成接口实现代理对象  
mybatis将以下代码自动在代理对象实现:  
User user = sqlSession.selectOne("test.findUserById", id);  
  
如何让mapper接口找到mapper.xml中statement的id。

1.1 第一步:开发mapper.xml映射文件

为了让mapper.xmlmapper.Java对应起来,将mapper.xml中的namespace设置为mapper.java的全限定名。

<mapper namespace="com.zwsafety.module.monitor.dao.DpaDetAlarmMapper" > 

1.2 第二步:开发mapper.java接口

Mybatis生成代理对象时,根据statement的标签决定调用 SqlSession的方法(selectinsertupdate..)

根据上边接口方法返回值 类型来决定 是调用 selectOne还是selectList,如果返回的是单个对象,动态代理调用selectOne(),如果返回的是集合对象,动态代理调用selectList()


1.3 Mapper开发规则

1、 在mapper.xml中将namespace设置为mapper.java的全限定名

2、 将mapper.java接口的方法名和mapper.xmlstatementid保持一致。

3、 将mapper.java接口的方法输入参数类型和mapper.xmlstatementparameterType保持一致

4、 将mapper.java接口的方法输出 结果类型和mapper.xmlstatementresultType保持一致


1.4 小结 

在企业中使用原始dao开发仍然的是很多的,主要是由于前期使用ibatis

建议使用mybatis动态代理方法,好处不用写实现类,开发快捷。使用动态代码方法需要遵循上边四点规范


原文地址:http://blog.csdn.net/liuqiang211/article/details/47338895

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
如果您想在 MyBatis 中使用 DAO 接口并且在多个数据源之间切换,可以使用 Spring 的 AbstractRoutingDataSource 实现动态数据源切换。下面是一些步骤: 1. 创建多个数据源,并将它们配置为 Spring 中的 bean。 2. 创建一个实现 AbstractRoutingDataSource 的,它将根据需要返回正确的数据源。 3. 在 DAO 接口中使用 @Repository 注解将其声明为 Spring bean。 4. 创建一个使用 @Mapper 注解的 Mapper 接口。 5. 在 Mapper 接口中定义 SQL 语句,并使用 @SelectProvider 注解将其映射到正确的 DAO 方法上。 6. 在 MyBatis 配置文件中定义 Mapper 接口的位置。 7. 在 Spring 配置文件中将所有的 Mapper 接口声明为 Spring bean。 8. 在 Spring 配置文件中将 AbstractRoutingDataSource bean 注入到需要使用多个数据源的 DAO bean 中。 9. 在 DAO 实现中使用 @Autowired 注解注入 AbstractRoutingDataSource bean,并在需要访问不同数据源的方法中使用 DataSourceUtils.getConnection() 获取正确的数据源连接。 10. 在需要访问不同数据源的方法中使用 MyBatis 的 SqlSessionTemplate 来执行 SQL 语句。在这里,您可以使用 SqlSessionTemplate 的 selectOne()、selectList()、insert()、update()、delete() 方法来执行 SQL 语句并返回结果。 注意:在使用 MyBatis 时,您需要将 DAO 接口Mapper 接口分开,并在 MyBatis 配置文件中定义 Mapper 接口的位置。在 DAO 接口中,您不需要定义 SQL 语句,而是在 Mapper 接口中定义 SQL 语句。在 Mapper 接口中,您使用 @SelectProvider、@InsertProvider、@UpdateProvider、@DeleteProvider 注解将 SQL 语句映射到正确的 DAO 方法上。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值