您的位置:首页 > 编程语言 > Java开发

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

2017-02-17 19:33 316 查看
上一节,已经做了一个查询语句的简单测试,我们使用的是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
和接口名一致。

 
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  java Mybatis 接口编程