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视频教程学习哦!
提枪策马乘胜追击04-21 20:01
代码小兵92504-17 16:07
代码小兵98804-25 13:57
杨晶珍05-11 14:54