黄视频网站在线免费观看-黄视频网站在线看-黄视频网站在线观看-黄视频网站免费看-黄视频网站免费观看-黄视频网站免费

千鋒教育-做有情懷、有良心、有品質的職業教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術干貨  > MyBatis之動態SQL語句

MyBatis之動態SQL語句

來源:千鋒教育
發布人:小鋒
時間: 2019-09-11 16:34:00 1568190840

  前言

  我們在進行項目開發時,經常遇到需要根據不同的需求,對原有SQL語句的內容進行修改,原來這是一個比較頭疼的問題,因為需要對原有SQL語句進行拼接、重組,費時費力還容易出錯,今天我們將學習MyBatis的動態SQL功能,可以解決這個問題。

  動態SQL語句簡介

  動態SQL語句是MyBatis的一個非常強大的功能,允許我們根據不同的需求,組合出不同的SQL語句,在select、update、insert、delete標簽中都可以添加動態SQL語句。

  IF標簽

  IF標簽可以在條件成立時,在SQL語句中插入IF標簽中的內容,不成立就不插入

  示例:

  <select id="selectUserByUser" parameterType="User" resultMap="userMap">

  select * from tb_user where

  <if test="realname != null">

  u_realname=#{realname}

  </if>

  <if test="gender != null">

  and u_gender=#{gender}

  </if>

  </select>

  上面代碼中是按照User對象的各個屬性進行查詢,如果姓名不為空就插入姓名作為條件,如果性別不為空就插入性別作為條件。

  但是我們會發現如果姓名為空,性別不為空,SQL語句就會變成:select * from tb_user where and u_gender=#{gender}

  或者姓名、性別都為空就會變成:select * from tb_user where

  這樣都會出現語法錯誤,這樣我們就需要下一個標簽:where

  Where標簽

  Where標簽 用于配置where條件,會去掉多余的and或or,如果一個條件都不成立,會自動去掉sql中的where。

  代碼改為:

  <select id="selectUserByUser" parameterType="User" resultMap="userMap">

  select * from tb_user

  <where>

  <if test="realname != null">

  u_realname=#{realname}

  </if>

  <if test="gender != null">

  and u_gender=#{gender}

  </if>

  <if test="age != null">

  and u_age=#{age}

  </if>

  </where>

  </select>

  這樣就不會出現上面可能的錯誤了

  Trim標簽

  上面where標簽的功能,也可以使用trim標簽實現,trim能去掉多余的前綴和后綴。

  語法:

  <trim prefix="前綴SQL" suffix="后綴" prefixOverrides="刪除前面的符號" suffixOverrides="刪除后面的符號">

  <if標簽>

  </trim>

  示例:

  <trim prefix="where" prefixOverrides="and|or">

  ...

  </trim>

  Set標簽

  用于配置update語句中的set部分,可以自動添加set關鍵字,刪除多余的逗號

  示例:

  <update id="update" parameterType="User">

  update tb_user

  <set>

  <if test="name != null">

  u_name=#{name},

  </if>

  <if test="password != null">

  u_password=#{password},

  </if>

  </set>

  where u_id=#{id}

  </update>

  也可以使用trim實現:

  <trim prefix="set" suffixOverrides=",">

  <if test="name != null">

  u_name=#{name},

  </if>

  ...

  </trim>

  Foreach標簽

  用于循環遍歷集合或數組的值,如:按多個人姓名查詢

  select * from tb_user where u_realname in ('張三','李四'....)

  語法:

  <foreach collection="集合名" item="變量名" index="下標名" open="開始符號" close="結束符號" seperator="分割符號">

  #{變量名}

  </foreach>

  注意:集合名在Mapper接口中需要使用@Param注解配置

  示例:

  <select id="selectUserByRealnames" resultMap="userMap">

  select * from tb_user where u_realname in

  <foreach collection="realnames" item="name" index="i" separator="," open="(" close=")">

  #{name}

  </foreach>

  </select>

  Choose標簽

  Java中有if,也會有if-else、switch語句來判斷多個條件,MyBatis也有Choose標簽可以進行多條件判斷

  示例:

  <select id="findActiveBlogLike"

  resultType="Blog">

  SELECT * FROM BLOG WHERE state = ‘ACTIVE’

  <choose>

  <when test="title != null">

  AND title like #{title}

  </when>

  <when test="author != null">

  AND author_name like #{author}

  </when>

  <otherwise>

  AND featured = 1

  </otherwise>

  </choose>

  </select>

  這里從第一個when進行判斷,如果成立就插入條件,結束choose標簽,如果不成立再判斷下一個when,如果所有when都不成立,就插入otherwise中的語句。

  總結

  動態SQL語句是MyBatis非常重要的特性,能夠讓我們根據不同需求組合SQL語句,而且不容易出錯。動態SQL的標簽有:if、where、set、choose、foreach等。掌握好它們我們可以寫出更加靈活、高效的數據庫操作代碼。

tags:
聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
10年以上業內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT
欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 日本特黄一级| 亚洲wwwwww| 精品视频在线观看免费| 久久国产精品只做精品| 亚洲www美色| 一本高清在线| 日韩免费在线| 久久国产一区二区| 日本免费乱人伦在线观看 | 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 九九精品影院| 沈樵在线观看福利| 日韩av成人| 国产视频一区二区三区四区| 国产激情视频在线观看| 亚洲第一页乱| 高清一级片| 午夜久久网| 99久久精品国产国产毛片| 免费国产一级特黄aa大片在线| 天天做日日爱| 天天色成人| 91麻豆爱豆果冻天美星空| 国产麻豆精品免费密入口| 欧美日本免费| 日韩中文字幕一区| 午夜欧美成人香蕉剧场| 国产网站免费视频| 国产原创视频在线| 欧美国产日韩在线| 91麻豆精品国产片在线观看| 四虎影视久久久免费| 欧美国产日韩在线| 韩国三级一区| 精品视频免费看| 日韩一级黄色大片| 一级女性全黄生活片免费| 精品在线观看一区| 精品国产三级a| 91麻豆国产| 国产高清在线精品一区二区| 欧美激情一区二区三区在线播放| 亚洲 激情| 超级乱淫伦动漫| 国产成人精品综合久久久| 国产一区免费在线观看| 久草免费资源| 国产成人精品综合在线| 香蕉视频久久| 欧美1卡一卡二卡三新区| 亚洲女初尝黑人巨高清在线观看| 国产不卡高清| 91麻豆爱豆果冻天美星空| 久久精品大片| 国产伦精品一区二区三区无广告| 色综合久久天天综合观看| 成人免费高清视频| 国产伦久视频免费观看视频| 国产激情视频在线观看| 国产亚洲精品成人a在线| 国产网站免费观看| 欧美激情一区二区三区视频| 国产91精品露脸国语对白| 亚欧视频在线| 欧美大片aaaa一级毛片| 国产麻豆精品高清在线播放| 日韩中文字幕在线播放| 国产视频网站在线观看| 日韩字幕在线| 99色视频| 国产精品自拍在线| 欧美日本免费| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | a级毛片免费观看网站| 国产精品12| 日本伦理网站| 午夜欧美成人香蕉剧场| 久久99爰这里有精品国产| 欧美激情一区二区三区视频| 91麻豆国产| 欧美1卡一卡二卡三新区| 国产精品1024在线永久免费 | 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 日本免费乱理伦片在线观看2018| 色综合久久天天综合观看| 欧美电影免费看大全| 精品国产一区二区三区精东影业| 九九久久国产精品| 韩国三级一区| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 色综合久久天天综线观看| 精品国产亚洲人成在线| 99色吧| 欧美激情影院| 99久久网站| 欧美一级视| 久久99爰这里有精品国产| 一级女性全黄久久生活片| 色综合久久手机在线| 日日爽天天| 日韩综合| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 国产成a人片在线观看视频| 九九精品久久久久久久久| 国产麻豆精品视频| 可以免费看污视频的网站| 国产一区免费在线观看| 国产伦精品一区二区三区无广告| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 91麻豆国产| 精品视频免费看| 国产一区二区精品尤物| 精品在线观看一区| 亚洲精品久久玖玖玖玖| 欧美激情在线精品video| 成人高清免费| 999精品视频在线| 久久国产一久久高清| 欧美国产日韩在线| 黄视频网站在线看| 国产a毛片| 国产一区免费在线观看| 精品在线视频播放| 美女免费毛片| 可以在线看黄的网站| 亚洲爆爽| 天堂网中文在线| 九九热国产视频| 午夜在线影院| 成人免费网站视频ww| 国产视频久久久久| 一级毛片视频在线观看| 国产激情一区二区三区| 欧美爱爱动态| 精品久久久久久影院免费| 日韩av东京社区男人的天堂| 国产一区二区精品在线观看| 黄视频网站在线看| 国产亚洲精品成人a在线| 亚洲天堂在线播放| 韩国毛片 免费| 天堂网中文在线| 日韩中文字幕一区| 国产视频网站在线观看| 一级毛片视频播放| 亚洲精品中文字幕久久久久久| 国产麻豆精品免费视频| 黄视频网站免费| 亚洲天堂在线播放| 黄色短视屏| 国产国语对白一级毛片| 美国一区二区三区| 国产一区二区精品| 成人a大片高清在线观看| 成人免费福利片在线观看| 国产伦久视频免费观看视频| 国产美女在线一区二区三区| 亚洲 国产精品 日韩| 日日日夜夜操| 韩国毛片| 久久99中文字幕| 国产一区免费在线观看| 欧美激情中文字幕一区二区| 99色视频在线| 国产国语在线播放视频| 午夜欧美成人香蕉剧场| 亚洲天堂在线播放| 精品国产一区二区三区久久久蜜臀 | 青青久久国产成人免费网站| 天天色成人| 亚飞与亚基在线观看| 免费一级片网站| 日本特黄一级| 国产视频一区二区三区四区| 精品视频在线看 | 久久福利影视| 免费的黄色小视频| 成人在免费观看视频国产| 天天色成人| 欧美18性精品| 国产极品精频在线观看| 超级乱淫伦动漫| 欧美大片一区| 国产伦精品一区二区三区无广告 | 国产伦精品一区二区三区无广告| 精品视频在线观看免费 | 韩国毛片免费大片| 青青久久精品| 欧美a级成人淫片免费看| 欧美国产日韩精品| 精品国产一区二区三区久久久狼| 国产伦精品一区二区三区在线观看 | 国产原创视频在线| 精品国产一区二区三区久| 国产视频在线免费观看| 国产激情一区二区三区| 日韩专区亚洲综合久久| 国产91丝袜高跟系列|