您好,登錄后才能下訂單哦!
這篇“MyBatis映射文件中parameterType與resultType怎么使用”文章的知識點(diǎn)大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細(xì),步驟清晰,具有一定的借鑒價(jià)值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“MyBatis映射文件中parameterType與resultType怎么使用”文章吧。
表示查詢結(jié)果集與java對象之間的一種關(guān)系,處理查詢結(jié)果集,映射到j(luò)ava對象。
resultMap 是一種“查詢結(jié)果集---Bean對象”屬性名稱映射關(guān)系,使用resultMap關(guān)系可將將查詢結(jié)果集中的列一一映射到bean對象的各個(gè)屬性(兩者屬性名可以不同,配置好映射關(guān)系即可),適用與復(fù)雜一點(diǎn)的查詢。
(1)適用于表的連接查詢(在resultMap里面可以配置連接條件,見如下程序association標(biāo)簽)
<!-- 訂單查詢關(guān)聯(lián)用戶的resultMap將整個(gè)查詢的結(jié)果映射到cn.itcast.mybatis.po.Orders中 --> <resultMap type="cn.itcast.mybatis.po.Orders" id="OrdersUserResultMap"> <!-- 配置映射的訂單信息 --> <!-- id:指定查詢列中的唯 一標(biāo)識,訂單信息的中的唯 一標(biāo)識,如果有多個(gè)列組成唯一標(biāo)識,配置多個(gè)id ,column:訂單信息的唯 一標(biāo)識列 ,property:訂單信息的唯 一標(biāo)識 列所映射到Orders中哪個(gè)屬性 --> <id column="id" property="id"/> <result column="user_id" property="userId"/> <result column="number" property="number"/> <result column="createtime" property="createtime"/> <result column="note" property=note/> <!-- 配置映射的關(guān)聯(lián)的用戶信息 --> <!-- association:用于映射關(guān)聯(lián)查詢單個(gè)對象的信息property:要將關(guān)聯(lián)查詢的用戶信息映射到Orders中哪個(gè)屬性 --> <association property="user" javaType="cn.itcast.mybatis.po.User"> <!-- id:關(guān)聯(lián)查詢用戶的唯 一標(biāo)識 column:指定唯 一標(biāo)識用戶信息的列 javaType:映射到user的哪個(gè)屬性--> <id column="user_id" property="id"/> <result column="username" property="username"/> <result column="sex" property="sex"/> <result column="address" property="address"/> </association> </resultMap>
2)適用于表的一對多連接查詢,(如,訂單對應(yīng)多個(gè)訂單明細(xì)時(shí),需要根據(jù)連接條件訂單id匹配訂單明細(xì),并且消除重復(fù)的訂單信息(訂單明細(xì)中的),如下程序);
<resultMap type="cn.itcast.mybatis.po.Orders" id="OrdersAndOrderDetailResultMap" extends="OrdersUserResultMap"> <!-- 訂單信息 --> <!-- 用戶信息 --> <!-- 使用extends繼承,不用在中配置訂單信息和用戶信息的映射 --> <!-- 訂單明細(xì)信息一個(gè)訂單關(guān)聯(lián)查詢出了多條明細(xì),要使用collection進(jìn)行映射 collection:對關(guān)聯(lián)查詢到多條記錄映射到集合對象中 property:將關(guān)聯(lián)查詢到多條記錄映射到cn.itcast.mybatis.po.Orders哪個(gè)屬性 ofType:指定映射到list集合屬性中pojo的類型 --> <collection property="orderdetails" ofType="cn.itcast.mybatis.po.Orderdetail"> <!-- id:訂單明細(xì)唯 一標(biāo)識 property:要將訂單明細(xì)的唯 一標(biāo)識 映射到cn.itcast.mybatis.po.Orderdetail的哪個(gè)屬性--> <id column="orderdetail_id" property="id"/> <result column="items_id" property="itemsId"/> <result column="items_num" property="itemsNum"/> <result column="orders_id" property="ordersId"/> </collection> </resultMap>
(3)映射的查詢結(jié)果集中的列標(biāo)簽可以根據(jù)需要靈活變化,并且,在映射關(guān)系中,還可以通過typeHandler設(shè)置實(shí)現(xiàn)查詢結(jié)果值的類型轉(zhuǎn)換,比如布爾型與0/1的類型轉(zhuǎn)換。
例如:
<resultMap type="hdu.terence.bean.Message" id="MessageResult"> <!--存放Dao值--><!--type是和數(shù)據(jù)庫對應(yīng)的bean類名Message--> <id column="id" jdbcType="INTEGER"property=" id"/><!--主鍵標(biāo)簽--> <result column="COMMAND" jdbcType="VARCHAR" property="command"/> <result column="DESCRIPTION" jdbcType="VARCHAR" property="description"/> <result column="CONTENT" jdbcType="VARCHAR" property="content"/> </resultMap> <select id="queryMessageList" parameterType="hdu.terence.bean.Message" resultMap="MessageResult"> SELECTID,COMMAND,DESCRIPTION,CONTENT FROM message WHERE 1=1 <if test="command!=null and!"".equals(command.trim())"> and COMMAND=#{command} </if> <if test="description!=null and!"".equals(description.trim())"> and DESCRIPTION like '%' #{description} '%' </if> </select>
resultType 是一種“查詢結(jié)果集---Bean對象”數(shù)據(jù)類型映射關(guān)系,使用resultType關(guān)系,即可使Bean對象接收查詢結(jié)果集;見名知意,該方法是通過查詢結(jié)果集中每條記錄(屬性)的數(shù)據(jù)類型和Bean對象的數(shù)據(jù)類型作映射,若兩者都相同,則表示匹配成功,Bean可以接收到查詢結(jié)果。
但是本方法有局限性,要求Bean對象字段名和查詢結(jié)果集的屬性名相同(可以大小寫不同,大小寫不敏感)。因?yàn)檫@個(gè)局限性,可以省略調(diào)resultMap進(jìn)行屬性名映射。
一般適用于pojo(簡單對象)類型數(shù)據(jù),簡單的單表查詢。
以下是resultType的寫法,將其值設(shè)置成對應(yīng)的java類上即可。不需要上述resultMap的映射關(guān)系。
<select resultType="User" id="findAll">select *from user </select>
<select resultType="com.itxiaotong.pojo.User" id="findById" parameterType="int">select *from user where id = #{userId} </select>
<select resultType="com.itxiaotong.pojo.User" id="findByUsernameLike" parameterType="string"> <bind value="'%'+username+'%'" name="likeName"/> select * from user where username like #{likeName} </select>
<select resultType="com.itxiaotong.pojo.User" id="findPage">select * from user limit #{param1},#{param2} </select> <select resultType="com.itxiaotong.pojo.User" id="findPage1">select * from user limit #{startIndex},#{pageSize} </select>
<select resultType="User" id="findPage2" parameterType="PageQuery">select * from user limit #{startIndex},#{pageSize} </select>
其中parameterType="PageQuery"的類是,下列內(nèi)容
PageQuery.java
package com.itxiaotong.pojo; public class PageQuery { private int startIndex; private int pageSize; public PageQuery() { } public PageQuery(int startIndex, int pageSize) { this.startIndex = startIndex; this.pageSize = pageSize; } public int getStartIndex() { return startIndex; } public void setStartIndex(int startIndex) { this.startIndex = startIndex; } public int getPageSize() { return pageSize; } public void setPageSize(int pageSize) { this.pageSize = pageSize; } }
<select resultType="com.itxiaotong.pojo.User" id="findPage3" parameterType="map">select * from user limit #{startIndex},#{pageSize} </select> <select resultType="int" id="findCount">select count(id) from user </select>
在mybatis映射接口的配置中,有select,insert,update,delete等元素都提到了parameterType的用法,parameterType為輸入?yún)?shù),在配置的時(shí)候,配置相應(yīng)的輸入?yún)?shù)類型即可。parameterType有基本數(shù)據(jù)類型和復(fù)雜的數(shù)據(jù)類型配置。
1.基本數(shù)據(jù)類型,如輸入?yún)?shù)只有一個(gè),其數(shù)據(jù)類型可以是基本的數(shù)據(jù)類型,也可以是自己定的類類型。包括int,String,Integer,Date,如下:
(1)根據(jù)id進(jìn)行相應(yīng)的刪除:
(2)添加員工:
2.復(fù)雜數(shù)據(jù)類型:包含java實(shí)體類,map。
parameterType例子(一)
現(xiàn)在有一個(gè)Mapper配置文件,以下是片段:
<select id="queryCommandListByPage" resultMap="CommandResult" > select <include refid="columns"/> from command a left join command_content b on a.id=b.command_id <where> <if test="command.name != null and !"".equals(command.name.trim())"> and a.name=#{command.name} </if> <if test="command.description != null and !"".equals(command.description.trim())"> and a.description like '%' #{command.description} '%' </if> </where> <if test="flag==1"> group by aid </if> order by id </select> <sql id="columns"> a.id aid,a.name,a.description,b.content,b.id,b.command_id </sql>
下面是IService接口:
/** * 攔截器實(shí)現(xiàn)分頁 */ public List<command> queryCommandListByPage(Map<String,Object>parameter);
parameterType例子(二)
<insert id="add" parameterType="com.itxiaotong.pojo.User">insert into user(username, sex, address)values (#{username}, #{sex}, #{address}) </insert>
<update id="update" parameterType="com.itxiaotong.pojo.User">update user set username = #{username},sex = #{sex},address=#{address} where id = #{id} </update>
<delete id="delete" parameterType="int">delete from user where id = #{id} </delete>
<insert id="add2" parameterType="com.itxiaotong.pojo.User"> <!-- keyProperty:主鍵屬性名 keyColumn:主鍵列名 resultType:主鍵類型 order:執(zhí)行時(shí)機(jī) --> <selectKey resultType="int" order="AFTER" keyColumn="id" keyProperty="id">SELECT LAST_INSERT_ID(); </selectKey> insert into user(username, sex, address)values (#{username}, #{sex}, #{address}) </insert>
<select resultType="com.itxiaotong.pojo.User" id="findPage3" parameterType="map">select * from user limit #{startIndex},#{pageSize} </select>
以上就是關(guān)于“MyBatis映射文件中parameterType與resultType怎么使用”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對大家有幫助,若想了解更多相關(guān)的知識內(nèi)容,請關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。