MyBatis中关于resultType和resultMap的区别

来源:互联网 发布:知乎 古驰 零售管培生 编辑:程序博客网 时间:2024/04/30 07:04

MyBatis中关于resultType和resultMap的区别

MyBatis中关于resultType和resultMap的区别

MyBatis中在查询进行select映射的时候,返回类型可以用resultType,也可以用resultMap,resultType是直接表示返回类型的(对应着我们的model对象中的实体),而resultMap则是对外部ResultMap的引用(提前定义了db和model之间的隐射key-->value关系),但是resultType跟resultMap不能同时存在。

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

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

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

  下面给出一个例子说明两者的使用差别:

package com.clark.model;import java.util.Date;public class Goods {  private Integer id;  private Integer cateId;  private String name;  private double price;  private String description;  private Integer orderNo;  private Date updateTime;    public Goods(){      }    public Goods(Integer id, Integer cateId, String name, double price,      String description, Integer orderNo, Date updateTime) {    super();    this.id = id;    this.cateId = cateId;    this.name = name;    this.price = price;    this.description = description;    this.orderNo = orderNo;    this.updateTime = updateTime;  }  public Integer getId() {    return id;  }  public void setId(Integer id) {    this.id = id;  }  public Integer getCateId() {    return cateId;  }  public void setCateId(Integer cateId) {    this.cateId = cateId;  }  public String getName() {    return name;  }  public void setName(String name) {    this.name = name;  }  public double getPrice() {    return price;  }  public void setPrice(double price) {    this.price = price;  }  public String getDescription() {    return description;  }  public void setDescription(String description) {    this.description = description;  }  public Integer getOrderNo() {    return orderNo;  }  public void setOrderNo(Integer orderNo) {    this.orderNo = orderNo;  }  public Date getTimeStamp() {    return updateTime;  }  public void setTimeStamp(Date updateTime) {    this.updateTime = updateTime;  }  @Override  public String toString() {    return "[goods include:Id="+this.getId()+",name="+this.getName()+        ",orderNo="+this.getOrderNo()+",cateId="+this.getCateId()+        ",updateTime="+this.getTimeStamp()+"]";  }}
<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN"  "http://mybatis.org/dtd/mybatis-3-config.dtd"><configuration>  <typeAliases>    <!-- give a alias for model -->    <typeAlias alias="goods" type="com.clark.model.Goods"></typeAlias>  </typeAliases>  <environments default="development">    <environment id="development">      <transactionManager type="JDBC" />      <dataSource type="POOLED">        <property name="driver" value="oracle.jdbc.driver.OracleDriver" />        <property name="url" value="jdbc:oracle:thin:@172.30.0.125:1521:oradb01" />        <property name="username" value="settlement" />        <property name="password" value="settlement" />      </dataSource>    </environment>  </environments>  <mappers>    <mapper resource="com/clark/model/goodsMapper.xml" />  </mappers></configuration></span>
<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"  "http://mybatis.org/dtd/mybatis-3-mapper.dtd"><mapper namespace="clark">  <resultMap type="com.clark.model.Goods" id="t_good">    <id column="id" property="id"/>    <result column="cate_id" property="cateId"/>    <result column="name" property="name"/>    <result column="price" property="price"/>    <result column="description" property="description"/>    <result column="order_no" property="orderNo"/>    <result column="update_time" property="updateTime"/>  </resultMap>  <!--resultMap 和   resultType的使用区别-->  <select id="selectGoodById" parameterType="int" resultType="goods">    select id,cate_id,name,price,description,order_no,update_time     from goods where id = #{id}  </select>    <select id="selectAllGoods" resultMap="t_good">    select id,cate_id,name,price,description,order_no,update_time from goods  </select>    <insert id="insertGood" parameterType="goods">    insert into goods(id,cate_id,name,price,description,order_no,update_time)      values(#{id},#{cateId},#{name},#{price},#{description},#{orderNo},#{updateTime})  </insert></mapper>
package com.clark.mybatis;import java.io.IOException;import java.io.Reader;import java.util.List;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.clark.model.Goods;public class TestGoods {  public static void main(String[] args) {    String resource = "configuration.xml";    try {      Reader reader = Resources.getResourceAsReader(resource);      SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(reader);      SqlSession session = sessionFactory.openSession();</span>
<span style="font-size:18px;"><span style="white-space:pre"></span>//使用resultType的情况      Goods goods = (Goods)session.selectOne("clark.selectGoodById", 4);      System.out.println(goods.toString());</span>
<span style="font-size:18px;"><span style="white-space:pre"></span>//使用resultMap的情况      List<Goods> gs = session.selectList("clark.selectAllGoods");      for (Goods goods2 : gs) {        System.out.println(goods2.toString());      }//Goods goods = new Goods(4, 12, "clark", 12.30, "test is ok", 5, new Date());//session.insert("clark.insertGood", goods);//session.commit();    } catch (IOException e) {      e.printStackTrace();    }  }}
结果输出为:
<span style="color:#cc0000;">[goods include:Id=4,name=clark,orderNo=null,cateId=null,updateTime=null]---使用resultType的结果</span>
<span style="color:#33ff33;">-------使用resultMap的结果-----------------</span>

[goods include:Id=4,name=clark,orderNo=5,cateId=12,updateTime=Wed Sep 17 15:29:58 CST 2014][goods include:Id=1,name=诺基亚N85,orderNo=1,cateId=1,updateTime=Wed Sep 17 13:52:51 CST 2014]

[goods include:Id=2,name=金立 A30,orderNo=2,cateId=1,updateTime=Wed Sep 17 13:53:11 CST 2014][goods include:Id=3,name=金立 A30,orderNo=3,cateId=2,updateTime=Wed Sep 17 15:07:38 CST 2014]

0 0