国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - mybatis中mapper.xml文件的常用屬性及標簽講解

mybatis中mapper.xml文件的常用屬性及標簽講解

2022-01-24 12:43某某灬 Java教程

這篇文章主要介紹了mybatis中mapper.xml文件的常用屬性及標簽講解,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

${}和#{}的區別

#{}會自動在你要插入字段兩端 加上引號。例如:你寫的是order by #{username},傳的是 zhangsan,那么會解析成order by “zhangsan”。

${}是將傳入的數據直接顯示生成在sql中。如:order by ${user_id},如果傳入的值是111,那么解析成sql時的值為order by 111 如果傳入的值是id,則解析成的sql為order by id.

#{}: 解析為一個 JDBC 預編譯語句(prepared statement)的參數標記符,一個 #{ } 被解析為一個參數占位符 。

$ {}: 僅僅為一個純碎的 string 替換,在動態 SQL 解析階段將會進行變量替換。在使用order by 時,就需要使用$;

常見的屬性

屬性 作用
namespace 對應接口的路徑
id 表示此段sql執行語句的唯一標識,也是接口的方法名稱【必須一致才能找到方法】
parameterType 表示該sql語句中需要傳入的參數, 類型要與對應的接口方法的類型一致【可選】
resultMap 定義出參,調用已定義的映射管理器的id值
resultType 定義出參,匹配普通Java類型或自定義的pojo【出參類型若不指定,將為語句類型默認類型,如語句返回值為int】

常見標簽

< sql >標簽

該標簽主要定義復用的sql語句片段,在執行的sql語句標簽直接引用即可。可以提高編碼效率、簡化代碼和提高可讀性。

需要配置id熟悉,表示該sql片段的唯一標識。

引用:通過<include refid=" " / >標簽引用,refid的值就是< sql>的id屬性的值。

?
1
2
3
4
5
6
7
8
9
<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 >標簽

< where > : 主要用來替換sql語句中的where字段,他的作用主要是用來簡化sql語句中where條件判斷的書寫的

< if >:條件判斷標簽,配置屬性test=" 條件字符串 ",判斷是否滿足條件,滿足則執行,不滿足則跳過。

?
1
2
3
4
5
6
7
8
<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> 

  

如果當id值為空時,此時打印的sql應是:select * from user where name=“xx” and age=“xx”

where 標記會自動將其后第一個條件的and或者是or給忽略掉

< set >標簽

< set > : 主要用來替換sql語句中的set字段,一般在update中使用。

?
1
2
3
4
5
6
7
8
<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> 

在上述的代碼片段當中,假如說現在三個字段都有值得話,那么上面打印的SQL語句如下:

?
1
update user set name=‘xxx' , age=‘xx' where id=‘x'

在上面age="xx"的后是沒有逗號的,也就是說set標記已經自動幫助我們把最后一個逗號給去掉了

set 標記會自動將其后第一個條件后的逗號忽略掉

< trim>標簽

< trim > : 是一個格式化的標記,可以完成set或者是where標記的功能。

示例1:

?
1
2
3
4
5
 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>

假如說name和age的值都不為null的話打印的SQL為:select * from user where name = ‘xx' and age = ‘xx'

在where的后面是不存在第一個and的,上面兩個屬性的意思如下:

  • prefix:前綴      
  • prefixoverride:去掉第一個and或者是or

示例2:

?
1
2
3
4
5
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>

假如說name和age的值都不為null的話打印的SQL為:update user set name=‘xx' , age=‘xx' where id=‘x'

在age='xx'的后面不存在逗號,而且自動加了一個set前綴和where后綴,上面三個屬性的意義如下,其中prefix意義如上:

  • suffixoverride:去掉最后一個逗號(也可以是其他的標記,就像是上面前綴中的and一樣)
  • suffix:后綴

< choose >標簽

< where > : choose標簽是按順序判斷其內部when標簽中的test條件出否成立,如果有一個成立,則 choose 結束。當 choose 中所有 when 的條件都不滿則時,則執行 otherwise 中的sql。類似于Java 的 switch 語句,choose 為 switch,when 為 case,otherwise 則為 default。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
<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文件中標簽錯誤

mybatis 的xml文件中對應關系,如果包含一對一和一對多,那么一對一的標簽association必須放在collection前面,resultMap內的標簽的都是有順序的。

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持服務器之家。

原文鏈接:https://blog.csdn.net/weixin_43882997/article/details/85625805

延伸 · 閱讀

精彩推薦
  • Java教程20個非常實用的Java程序代碼片段

    20個非常實用的Java程序代碼片段

    這篇文章主要為大家分享了20個非常實用的Java程序片段,對java開發項目有所幫助,感興趣的小伙伴們可以參考一下 ...

    lijiao5352020-04-06
  • Java教程Java實現搶紅包功能

    Java實現搶紅包功能

    這篇文章主要為大家詳細介紹了Java實現搶紅包功能,采用多線程模擬多人同時搶紅包,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙...

    littleschemer13532021-05-16
  • Java教程Java使用SAX解析xml的示例

    Java使用SAX解析xml的示例

    這篇文章主要介紹了Java使用SAX解析xml的示例,幫助大家更好的理解和學習使用Java,感興趣的朋友可以了解下...

    大行者10067412021-08-30
  • Java教程升級IDEA后Lombok不能使用的解決方法

    升級IDEA后Lombok不能使用的解決方法

    最近看到提示IDEA提示升級,尋思已經有好久沒有升過級了。升級完畢重啟之后,突然發現好多錯誤,本文就來介紹一下如何解決,感興趣的可以了解一下...

    程序猿DD9332021-10-08
  • Java教程Java8中Stream使用的一個注意事項

    Java8中Stream使用的一個注意事項

    最近在工作中發現了對于集合操作轉換的神器,java8新特性 stream,但在使用中遇到了一個非常重要的注意點,所以這篇文章主要給大家介紹了關于Java8中S...

    阿杜7482021-02-04
  • Java教程xml與Java對象的轉換詳解

    xml與Java對象的轉換詳解

    這篇文章主要介紹了xml與Java對象的轉換詳解的相關資料,需要的朋友可以參考下...

    Java教程網2942020-09-17
  • Java教程小米推送Java代碼

    小米推送Java代碼

    今天小編就為大家分享一篇關于小米推送Java代碼,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧...

    富貴穩中求8032021-07-12
  • Java教程Java BufferWriter寫文件寫不進去或缺失數據的解決

    Java BufferWriter寫文件寫不進去或缺失數據的解決

    這篇文章主要介紹了Java BufferWriter寫文件寫不進去或缺失數據的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望...

    spcoder14552021-10-18
主站蜘蛛池模板: 最近的中文字幕在线看视频 | 久久mm| 亚洲不卡在线 | 中文字幕在线观看 | 欧美在线观看免费观看视频 | аⅴ资源新版在线天堂 | 日韩在线不卡 | 91精品国产综合久久久久久 | 国产99精品在线 | 伊人久久在线 | 日韩欧美一区二区三区免费观看 | 成人中文字幕在线观看 | 午夜www | 一区二区三区精品视频 | 国内成人自拍视频 | 互换娇妻呻吟hd中文字幕 | 精品国产黄a∨片高清在线 91精品国产91久久久 | av官网| av亚洲在线 | 免费黄色在线观看 | 亚洲性视频 | 在线欧美日韩 | 午夜视频在线播放 | 欧美xxxx黑人又粗又长 | 免费自拍视频 | 亚洲人视频在线观看 | 五月婷婷色网 | 观看av | 国产麻豆乱码精品一区二区三区 | 亚洲va欧美va人人爽成人影院 | 黄色a级网站 | 午夜激情在线免费观看 | 日韩视频精品在线 | 在线观看国产视频 | 欧美在线视频一区 | 国产精品久久久久久亚洲调教 | 亚洲人视频在线观看 | 亚洲精品乱码久久久久久麻豆不卡 | 亚洲精品日韩激情在线电影 | 26uuu成人免费毛片 | 老师的朋友2|