mybatis中mapper.xml文件的常用屬性及標(biāo)簽講解
${}和#{}的區(qū)別
#{}會(huì)自動(dòng)在你要插入字段兩端 加上引號(hào)。例如:你寫的是order by #{username},傳的是 zhangsan,那么會(huì)解析成order by “zhangsan”。
${}是將傳入的數(shù)據(jù)直接顯示生成在sql中。如:order by ${user_id},如果傳入的值是111,那么解析成sql時(shí)的值為order by 111 如果傳入的值是id,則解析成的sql為order by id.
#{}: 解析為一個(gè) JDBC 預(yù)編譯語(yǔ)句(prepared statement)的參數(shù)標(biāo)記符,一個(gè) #{ } 被解析為一個(gè)參數(shù)占位符 。
$ {}: 僅僅為一個(gè)純碎的 string 替換,在動(dòng)態(tài) SQL 解析階段將會(huì)進(jìn)行變量替換。在使用order by 時(shí),就需要使用$;
常見(jiàn)的屬性
屬性 | 作用 |
---|---|
namespace | 對(duì)應(yīng)接口的路徑 |
id | 表示此段sql執(zhí)行語(yǔ)句的唯一標(biāo)識(shí),也是接口的方法名稱【必須一致才能找到方法】 |
parameterType | 表示該sql語(yǔ)句中需要傳入的參數(shù), 類型要與對(duì)應(yīng)的接口方法的類型一致【可選】 |
resultMap | 定義出參,調(diào)用已定義的映射管理器的id值 |
resultType | 定義出參,匹配普通Java類型或自定義的pojo【出參類型若不指定,將為語(yǔ)句類型默認(rèn)類型,如語(yǔ)句返回值為int】 |
常見(jiàn)標(biāo)簽
< sql >標(biāo)簽
該標(biāo)簽主要定義復(fù)用的sql語(yǔ)句片段,在執(zhí)行的sql語(yǔ)句標(biāo)簽直接引用即可??梢蕴岣呔幋a效率、簡(jiǎn)化代碼和提高可讀性。
需要配置id熟悉,表示該sql片段的唯一標(biāo)識(shí)。
引用:通過(guò)<include refid=" " / >標(biāo)簽引用,refid的值就是< sql>的id屬性的值。
<sql id="Base_Column_List"> id, question, answer </sql> <select id="selectByPrimaryKey" parameterType="java.lang.Long" resultMap="BaseResultMap"> select <include refid="Base_Column_List" /> from java where id = #{id,jdbcType=BIGINT} </select>
< where >和< if >標(biāo)簽
< where > : 主要用來(lái)替換sql語(yǔ)句中的where字段,他的作用主要是用來(lái)簡(jiǎn)化sql語(yǔ)句中where條件判斷的書(shū)寫的
< if >:條件判斷標(biāo)簽,配置屬性test=" 條件字符串 ",判斷是否滿足條件,滿足則執(zhí)行,不滿足則跳過(guò)。
<select id="selectByParams" parameterType="map" resultType="user"> select * from user <where> <if test="id != null ">id=#{id}</if> <if test="name != null and name.length()>0" >and name=#{name}</if> <if test="age != null and age.length()>0">and age = #{age}</if> </where> </select>
如果當(dāng)id值為空時(shí),此時(shí)打印的sql應(yīng)是:select * from user where name=“xx” and age=“xx”
where 標(biāo)記會(huì)自動(dòng)將其后第一個(gè)條件的and或者是or給忽略掉
< set >標(biāo)簽
< set > : 主要用來(lái)替換sql語(yǔ)句中的set字段,一般在update中使用。
<update> update user <set> <if test="name != null and name.length()>0">name = #{name},</if> <if test="age != null and age .length()>0">age = #{age },</if> </set> where id = #{id} </update>
在上述的代碼片段當(dāng)中,假如說(shuō)現(xiàn)在三個(gè)字段都有值得話,那么上面打印的SQL語(yǔ)句如下:
update user set name=‘xxx' , age=‘xx' where id=‘x'
在上面age="xx"的后是沒(méi)有逗號(hào)的,也就是說(shuō)set標(biāo)記已經(jīng)自動(dòng)幫助我們把最后一個(gè)逗號(hào)給去掉了
set 標(biāo)記會(huì)自動(dòng)將其后第一個(gè)條件后的逗號(hào)忽略掉
< trim>標(biāo)簽
< trim > : 是一個(gè)格式化的標(biāo)記,可以完成set或者是where標(biāo)記的功能。
示例1:
select * from user <trim prefix="WHERE" prefixoverride="AND |OR"> <if test="name != null and name.length()>0"> AND name=#{name}</if> <if test="age != null and age.length()>0"> AND age=#{age}</if> </trim>
假如說(shuō)name和age的值都不為null的話打印的SQL為:select * from user where name = ‘xx' and age = ‘xx'
在where的后面是不存在第一個(gè)and的,上面兩個(gè)屬性的意思如下:
- prefix:前綴
- prefixoverride:去掉第一個(gè)and或者是or
示例2:
update user <trim prefix="set" suffixoverride="," suffix=" where id = #{id} "> <if test="name != null and name.length()>0"> name=#{name} , </if> <if test="age!= null and age.length()>0"> age=#{age} , </if> </trim>
假如說(shuō)name和age的值都不為null的話打印的SQL為:update user set name=‘xx' , age=‘xx' where id=‘x'
在age='xx'的后面不存在逗號(hào),而且自動(dòng)加了一個(gè)set前綴和where后綴,上面三個(gè)屬性的意義如下,其中prefix意義如上:
- suffixoverride:去掉最后一個(gè)逗號(hào)(也可以是其他的標(biāo)記,就像是上面前綴中的and一樣)
- suffix:后綴
< choose >標(biāo)簽
< where > : choose標(biāo)簽是按順序判斷其內(nèi)部when標(biāo)簽中的test條件出否成立,如果有一個(gè)成立,則 choose 結(jié)束。當(dāng) choose 中所有 when 的條件都不滿則時(shí),則執(zhí)行 otherwise 中的sql。類似于Java 的 switch 語(yǔ)句,choose 為 switch,when 為 case,otherwise 則為 default。
<select id="selectByParams" parameterType="map" resultType="user"> select * from user where 1 = 1 <choose> <when test="id !=null "> AND id = #{id} </when > <when test="username != null and username != '' "> AND username = #{username} </when > <when test="age != null and age !=''"> AND age = #{age} </when > <otherwise> </otherwise> </choose> </select>
mybatis 的xml文件中標(biāo)簽錯(cuò)誤
mybatis 的xml文件中對(duì)應(yīng)關(guān)系,如果包含一對(duì)一和一對(duì)多,那么一對(duì)一的標(biāo)簽association必須放在collection前面,resultMap內(nèi)的標(biāo)簽的都是有順序的。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
SpringBoot集成WebSocket實(shí)現(xiàn)后臺(tái)向前端推送信息的示例
這篇文章主要介紹了SpringBoot集成WebSocket實(shí)現(xiàn)后臺(tái)向前端推送信息的示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12Java開(kāi)發(fā)SSM框架微信支付的實(shí)現(xiàn)
這篇文章主要介紹了Java開(kāi)發(fā)SSM框架微信支付的實(shí)現(xiàn),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-10-10在Spring Boot框架中使用AOP的正確姿勢(shì)
aop是spring的兩大功能模塊之一,功能非常強(qiáng)大,為解耦提供了非常優(yōu)秀的解決方案。下面這篇文章主要給大家介紹了如何在Spring Boot框架中使用AOP的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2018-08-08Spring中使用事務(wù)嵌套時(shí)需要警惕的問(wèn)題分享
最近項(xiàng)目上有一個(gè)使用事務(wù)相對(duì)復(fù)雜的業(yè)務(wù)場(chǎng)景報(bào)錯(cuò)了。在絕大多數(shù)情況下,都是風(fēng)平浪靜,沒(méi)有問(wèn)題。其實(shí)內(nèi)在暗流涌動(dòng),在有些異常情況下就會(huì)報(bào)錯(cuò),這種偶然性的問(wèn)題很有可能就會(huì)在暴露到生產(chǎn)上造成事故,那究竟是怎么回事呢?本文就來(lái)簡(jiǎn)單講講2023-04-04Java如何根據(jù)key值修改Hashmap中的value值
這篇文章主要介紹了Java如何根據(jù)key值修改Hashmap中的value值問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03