博为峰JavaEE技术文章 ——MyBatis 接口编程

上一节,已经做了一个查询语句的简单测试,我们使用的是SqlSession实例来直接执行映射的SQL语句:

session.selectOne("com.bwf.dao.IUserDao.selectUserByID", 1);

这种方式需明确的写出mapper的命名空间以及select元素的id,这样做很容易出现文字输入错误,也不够安全。

Mybatis还支持更简单的方法,而且是更好更通用的方法,即:面向接口编程。可以定义一个接口(比如IUserDao),定义一个与mapper中的select元素相对应的方法,其中参数和返回类型与select定义保持一致即可。如对上一节例子中的select元素,我们可以写一个如下的接口:


需要注意的是,这个方法名 selectUserByID 必须与 mapper xml 里面配置的 select 元素的id 一致(<select id="selectUserByID")。

接下来我们重写上一个例子的测试代码,修改main函数的相关内容:


运行可以得到与之前相同的结果。

其中IUserDao iud = session.getMapper(IUserDao.class),是由Mybatis实现了接口的代理类。

面向接口的方式,必须要注意,在mapper xml的配置文件中,<mapper namespace="com.bwf.dao.IUserDao"> ,命名空间不能有错,必须与我们定义的接口的完整名称一致,即:package 和接口名一致。

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值