动力节点首页 全国咨询热线:400-8080-105

绑定手机号,登录
手机号

验证码

微信登录
手机号登录
手机号

验证码

微信登录与注册
微信扫码登录与注册

扫码关注微信公众号完成登录与注册
手机号登录
首页 > 文章

Mybatis返回值类型

07-15 12:10 623浏览
举报 T字号
  • 大字
  • 中字
  • 小字

MyBatis的返回参数类型分两种

1. 对应的分类为:

resultMap:

resultType:

2 .对应返回值类型:

resultMap:结果集

resultType:int,string ,long ,class

3. 注意点:

在MyBatis进行查询映射时,其实查询出来的每一个属性都是放在一个对应的Map里面的,其中键是属性名,值则是其对应的值。

当提供的返回类型属性是resultType时,MyBatis会将Map里面的键值对取出赋给resultType所指定的对象对应的属性。所以其实MyBatis的每一个查询映射的返回类型都是ResultMap,只是当提供的返回类型属性是resultType的时

候,MyBatis对自动的给把对应的值赋给resultType所指定对象的属性。

当提供的返回类型是resultMap时,因为Map不能很好表示领域模型,就需要自己再进一步的把它转化为对应的对象,这常常在复杂查询中很有作用。

当返回类型直接是一个ResultMap的时候也是非常有用的,这主要用在进行复杂联合查询上,因为进行简单查询是没有什么必要的

     <resultMap type="com.dw.entity.User" id="UserMap">
        <result column="username" property="username"/>
        <result column="password" property="password"/>
     </resultMap>
     <select id="selectMap" resultMap="UserMap"> 
        select * from user
     </select>
  @Test
  public void testSelectMap(){
	  init();  
      @SuppressWarnings("unchecked")
	  List<User> list = userDao.selectMap();
	  session.commit();
      for (User user : list) {
		System.out.println(user);
	}
	  destory();
  }
 public List selectMap();

当然这里用resultType同样可以完成,resultMap的优势主要在于联合查询

获取记录总数count(*):

     <select id="countUser" resultType="int">
       select count(*) from user
     </select>
  @Test
  public void testCountUser(){
	  init();  
      int count = userDao.countUser();
	  session.commit();
	  System.out.println("count:"+count);
	  destory();
  }

初始化和“善后处理”:

	private void init(){
		try {
			inputStream = Resources.getResourceAsStream("config.xml");
			sessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
			session = sessionFactory.openSession();
			userDao = session.getMapper(UserDao.class);
		} catch (IOException e) {
			e.printStackTrace();
		}
	}
	
	private void destory(){
		if(session != null){
			session.close();
		}
		if(inputStream != null){
			try {
				inputStream.close();
			} catch (IOException e) {
				e.printStackTrace();
			}
		}
	} 

动力节点在线课程涵盖零基础入门,高级进阶,在职提升三大主力内容,覆盖Java从入门到就业提升的全体系学习内容。全部Java视频教程免费观看,相关学习资料免费下载!对于火爆技术,每周一定时更新!如果想了解更多相关技术,可以到动力节点在线免费观看MyBatis视频教程学习哦!

1人推荐
共同学习,写下你的评论
0条评论
代码小兵872
程序员代码小兵872

30篇文章贡献98658字

相关课程 更多>

作者相关文章更多>

推荐相关文章更多>

Java面试题及答案整理

提枪策马乘胜追击04-21 20:01

Spring常见面试题

代码小兵92504-17 16:07

Java零基础实战项目——五子棋

代码小兵98804-25 13:57

Java string类详解

杨晶珍05-11 14:54

6道经典算法面试题

杨晶珍05-12 16:39

发评论

举报

0/150

取消