亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Mybatis-Mapper.xml文件前綴詳解

 更新時(shí)間:2023年09月25日 09:24:42   作者:一劍荒蕪  
這篇文章主要介紹了Mybatis-Mapper.xml文件前綴,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

Mybatis-Mapper.xml文件前綴

<?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="">
</mapper>

mybatis中mapper.xml文件常用屬性及標(biāo)簽

${}和#{}的區(qū)別

#{}會(huì)自動(dòng)在你要插入字段兩端 加上引號(hào)。例如:你寫(xiě)的是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í),也是接口的方法名稱(chēng)【必須一致才能找到方法】
parameterType表示該sql語(yǔ)句中需要傳入的參數(shù), 類(lèi)型要與對(duì)應(yīng)的接口方法的類(lèi)型一致【可選】
resultMap定義出參,調(diào)用已定義的映射管理器的id值
resultType定義出參,匹配普通Java類(lèi)型或自定義的pojo【出參類(lèi)型若不指定,將為語(yǔ)句類(lèi)型默認(rèn)類(lèi)型,如語(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ū)寫(xiě)的

< 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。

類(lèi)似于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>   

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 一篇文章帶你深入理解JVM虛擬機(jī)讀書(shū)筆記--鎖優(yōu)化

    一篇文章帶你深入理解JVM虛擬機(jī)讀書(shū)筆記--鎖優(yōu)化

    這篇文章深入介紹了JVM虛擬機(jī)的鎖優(yōu)化,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2021-09-09
  • Java控制流程示例代碼詳解

    Java控制流程示例代碼詳解

    這篇文章主要介紹了Java控制流程,本文通過(guò)示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-03-03
  • 在IDEA中配置Maven鏡像的最新方法

    在IDEA中配置Maven鏡像的最新方法

    這篇文章主要給大家介紹了關(guān)于在IDEA中配置Maven鏡像的最新方法,Maven是一個(gè)流行的Java項(xiàng)目構(gòu)建工具,它依賴于互聯(lián)網(wǎng)上的Mave中央倉(cāng)庫(kù)來(lái)下載和管理項(xiàng)目依賴庫(kù),文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2023-11-11
  • java實(shí)現(xiàn)sftp客戶端上傳文件以及文件夾的功能代碼

    java實(shí)現(xiàn)sftp客戶端上傳文件以及文件夾的功能代碼

    本篇文章主要介紹了java實(shí)現(xiàn)sftp客戶端上傳文件以及文件夾的功能代碼,具有一定的參考價(jià)值,有興趣的可以了解一下。
    2017-02-02
  • java集合Collection實(shí)現(xiàn)類(lèi)解析ArrayList?LinkedList及Vector

    java集合Collection實(shí)現(xiàn)類(lèi)解析ArrayList?LinkedList及Vector

    這篇文章主要為大家介紹了java集合Collection實(shí)現(xiàn)類(lèi)解析ArrayList?LinkedList及Vector,有需要的朋友可以借鑒參考下,希望能夠有所幫助
    2022-03-03
  • 基于SpringBoot實(shí)現(xiàn)驗(yàn)證碼功能的代碼及思路

    基于SpringBoot實(shí)現(xiàn)驗(yàn)證碼功能的代碼及思路

    SpringBoot技術(shù)是目前市面上從事JavaEE企業(yè)級(jí)開(kāi)發(fā)過(guò)程中使用量最大的技術(shù),下面這篇文章主要給大家介紹了如何基于SpringBoot實(shí)現(xiàn)驗(yàn)證碼功能的相關(guān)資料,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-07-07
  • Spring Boot集成Kafka的示例代碼

    Spring Boot集成Kafka的示例代碼

    本篇文章主要介紹了Spring Boot集成Kafka的示例代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-04-04
  • Java實(shí)現(xiàn)字符串匹配的示例代碼

    Java實(shí)現(xiàn)字符串匹配的示例代碼

    這篇文章主要介紹了Java實(shí)現(xiàn)字符串匹配,本文通過(guò)示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-04-04
  • Spring SmartLifecycle:如何精準(zhǔn)控制Bean的生命周期

    Spring SmartLifecycle:如何精準(zhǔn)控制Bean的生命周期

    這篇文章主要介紹了Spring SmartLifecycle:如何精準(zhǔn)控制Bean的生命周期問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2025-03-03
  • 使用IDEA異常斷點(diǎn)來(lái)定位java.lang.ArrayStoreException的問(wèn)題

    使用IDEA異常斷點(diǎn)來(lái)定位java.lang.ArrayStoreException的問(wèn)題

    這篇文章主要介紹了使用IDEA異常斷點(diǎn)來(lái)定位java.lang.ArrayStoreException的問(wèn)題,平常開(kāi)發(fā)過(guò)程中面對(duì)這種描述不夠清楚,無(wú)法定位具體原因的問(wèn)題該如何處理,下面我們來(lái)一起學(xué)習(xí)一下吧
    2019-06-06

最新評(píng)論