一、不使用@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>