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不能很好表示領域模型,就需要自己再進一步的把它轉化為對應的對象,這常常在復雜查詢中很有作用。
下面給出一個例子說明兩者的使用差別:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
|
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()+ "]" ; } } |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
<?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> |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
<?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> |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
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> |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
<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> [html] view plain copy 在CODE上查看代碼片派生到我的代碼片 <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(); } } } |
結果輸出為:
1
2
|
<span style= "color:#cc0000;" >[goods include:Id= 4 ,name=clark,orderNo= null ,cateId= null ,updateTime= null ]---使用resultType的結果</span> <span style= "color:#33ff33;" >-------使用resultMap的結果-----------------</span> |
以上所述是小編給大家介紹的MyBatis中關于resultType和resultMap的區別介紹,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對服務器之家網站的支持!
原文鏈接:http://blog.csdn.net/caolipeng_918/article/details/39344783?utm_source=tuicool&utm_medium=referral