时间:2021-05-20
前边阐述了如何在java项目中使用mybatis,我们使用的是映射文件的方式,在获得具体的数据操作方法时需要传入映射文件中namespace+“.”方法名称,这种方式有时候会感觉很不爽,很麻烦。我们在开发中不是常说要面向接口变成吗,mybatis也支持接口,下面在前面的例子的基础上做相应修改。
前面的例子的环境及映射文件均保持不变,如下是我的映射文件,
<mapper namespace="com.cn.inter.IMessageOperation"><select id="selectUserByID" parameterType="int" resultType="com.cn.imooc.entity.Message">select * from `message` where id = #{id}</select><select id="selectMessages" resultType="Message">select id,command,description,commentfrom message;</select></mapper>我们可以看到里边有namespace为com.cn.inter.ImessageOperation,现在我们创建这样一个包,com.cn.inter,在此包中创建接口IMessageOperation,接口中有一个方法,方法的签名为:public Message selectUserByID(Integer id);
我们创建的接口和映射文件做了一致对应,包括了方法名、返回值、参数列表。下面看测试方法
package com.cn.test;import java.io.Reader;import org.apache.ibatis.io.Resources;import org.apache.ibatis.session.SqlSession;import org.apache.ibatis.session.SqlSessionFactory;import org.apache.ibatis.session.SqlSessionFactoryBuilder;import com.cn.imooc.entity.Message;import com.cn.inter.IMessageOperation;public class MyTest2 {public static void main(String[] args) {// TODO Auto-generated method stubReader reader;SqlSession sqlSession=null;try{//从类路径下(src)读取mybatis配置文件reader=Resources.getResourceAsReader("Configuration.xml");SqlSessionFactory sqlSessionFactory=new SqlSessionFactoryBuilder().build(reader);sqlSession=sqlSessionFactory.openSession();//获得IMessageOperation接口IMessageOperation imo=sqlSession.getMapper(IMessageOperation.class);//调用接口的方法返回查询结果Message message=imo.selectMessageByIdI(new Integer(3));System.out.println(message);}catch(Exception e){e.printStackTrace();}finally{//如果sqlSession不为空,则关闭if(null!=sqlSession)sqlSession.close();}}}我们可以看到测试方法中调用数据操作的方法发生了变化,我们是先获得一个IMessageOperation的接口,然后调用其selectMessageByID方法,最后得到结果。可以感觉到比上一篇中的方式更加简单了,也更符合我们日常的编码规范了。
综合这两篇内容中的方式,使用任何一种都是可以的,只是两种不同的方式而已,我个人更倾向于后者。
以上所述是小编给大家介绍的MyBatis如何使用(二)的相关资料,非常不错,具有参考借鉴价值,希望对大家有所帮助!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
介绍使用mybatis时可以使用二级缓存提高查询速度,进而改善用户体验。使用redis做mybatis的二级缓存可是内存可控,管理方便。1.在pom.xml文件
在前边阐述了单独使用mybatis的方法,在实际开发过程中mybatis经常和spring一起使用,即mybatis和spring进行集成,现在我们来看如何集成
上一篇文章MyBatis入门学习教程(一)-MyBatis快速入门中我们讲了如何使用Mybatis查询users表中的数据,算是对MyBatis有一个初步的入门
前言在开发中使用Mybatis经常使用到#{}与${},依旧有很多开发者对二者的使用不是很清晰,正所谓好记性不如烂笔头,特此总结一下。在mybatis中动态sq
前面有写到Spring+SpringMVC+MyBatis深入学习及搭建(二)——MyBatis原始Dao开发和mapper代理开发MyBatis的全局配置文件