mybatis中@param的使用與否

一、不使用@paramjava

  DAO層:List<ShopCategory> queryShopCategory(ShopCategory shopCategory);:以對象爲參數mybatis

  mapper.xml:app

<select id="queryShopCategory" resultType="com.imooc.o2o.entity.ShopCategory">
		SELECT
		shop_category_id,
		shop_category_name,
		shop_category_desc,
		shop_category_img,
		priority,
		create_time,
		last_edit_time,
		parent_id
		FROM
		tb_shop_category
		<where>
			<!-- <if test="shopCategoryCondition.parent != null">
				and parent_id = #{shopCategoryCondition.parent.shopCategoryId}
			</if> -->
			<if test="parent != null">
				and parent_id = #{parent.shopCategoryId}
			</if>
		</where>
		ORDER BY 
		priority DESC
	</select>

  DO層:ide

 1 package com.imooc.o2o.entity;
 2 
 3 import java.util.Date;
 4 
 5 public class ShopCategory {
 6     
 7     private Long shopCategoryId;
 8     private String shopCategoryName;
 9     private String shopCategoryDesc;
10     private String shopCategoryImg;
11     private Integer priority;
12     private Date createTime;
13     private Date lastEditTime;
14     private ShopCategory parent;
15     public Long getShopCategoryId() {
16         return shopCategoryId;
17     }
18     public void setShopCategoryId(Long shopCategoryId) {
19         this.shopCategoryId = shopCategoryId;
20     }
21     public String getShopCategoryName() {
22         return shopCategoryName;
23     }
24     public void setShopCategoryName(String shopCategoryName) {
25         this.shopCategoryName = shopCategoryName;
26     }
27     public String getShopCategoryDesc() {
28         return shopCategoryDesc;
29     }
30     public void setShopCategoryDesc(String shopCategoryDesc) {
31         this.shopCategoryDesc = shopCategoryDesc;
32     }
33     public String getShopCategoryImg() {
34         return shopCategoryImg;
35     }
36     public void setShopCategoryImg(String shopCategoryImg) {
37         this.shopCategoryImg = shopCategoryImg;
38     }
39     public Integer getPriority() {
40         return priority;
41     }
42     public void setPriority(Integer priority) {
43         this.priority = priority;
44     }
45     public Date getCreateTime() {
46         return createTime;
47     }
48     public void setCreateTime(Date createTime) {
49         this.createTime = createTime;
50     }
51     public Date getLastEditTime() {
52         return lastEditTime;
53     }
54     public void setLastEditTime(Date lastEditTime) {
55         this.lastEditTime = lastEditTime;
56     }
57     public ShopCategory getParent() {
58         return parent;
59     }
60     public void setParent(ShopCategory parent) {
61         this.parent = parent;
62     }
63     @Override
64     public String toString() {
65         return "ShopCategory [shopCategoryId=" + shopCategoryId + ", shopCategoryName=" + shopCategoryName
66                 + ", shopCategoryDesc=" + shopCategoryDesc + ", shopCategoryImg=" + shopCategoryImg + ", priority="
67                 + priority + ", createTime=" + createTime + ", lastEditTime=" + lastEditTime + ", parent=" + parent
68                 + "]";
69     }
70     
71     
72 }

2.使用@paramthis

  DAO層:spa

List<ShopCategory> queryShopCategory(@Param("shopCategoryCondition") ShopCategory shopCategory);

  mapper.xml:code

  

 1 <?xml version="1.0" encoding="UTF-8"?>
 2 <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
 3     "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
 4 <mapper namespace="com.imooc.o2o.dao.ShopCategoryMapper">
 5     <select id="queryShopCategory" resultType="com.imooc.o2o.entity.ShopCategory">
 6         SELECT
 7         shop_category_id,
 8         shop_category_name,
 9         shop_category_desc,
10         shop_category_img,
11         priority,
12         create_time,
13         last_edit_time,
14         parent_id
15         FROM
16         tb_shop_category
17         <where>
18             <if test="shopCategoryCondition.parent != null">
19                 and parent_id = #{shopCategoryCondition.parent.shopCategoryId}
20             </if>
24         </where>
25         ORDER BY 
26         priority DESC
27     </select>
28 </mapper>

 

由此能夠看出,mybatis在xml中作值的注入時,如果不使用@param,則若參數爲對象,則在#{}中則直接寫對象中的屬性。沒法根據對象來綁定。例如上例中的and parent_id = #{parent.shopCategoryId}。參數爲ShopCategory。可是因爲沒有用xml

@param作參數別名,所以在#{}沒法直接引用參數,只能直接經過對象參數的屬性來進行#{}注入。對象

可是若是使用了@param。則對象參數在進行#{}注入時能夠使用別名。例以下例子中 shopCategoryCondition就是DAO層定義的方法中的參數shopCategory的別名blog

  <if test="shopCategoryCondition.parent != null">
      and parent_id = #{shopCategoryCondition.parent.shopCategoryId}
  </if>
相關文章
相關標籤/搜索