Mybatis深入瞭解(五)----動態SQL
什麼是動態SQL?
動態sql是mybatis的核心,主要是對sql語句進行靈活操作,通過表示式進行判斷,對sql進行靈活的拼接、組裝。
例項
使用者資訊綜合查詢列表和使用者資訊查詢列表總數這兩個statement的定義使用動態sql。對查詢條件進行判斷,如果輸入引數不為空才進行查詢條件拼接。
Mapper.xml
<!-- 使用者資訊綜合查詢
#{userCustom.sex}:取出pojo包裝物件中性別值
${userCustom.username}:取出pojo包裝物件中使用者名稱稱
-->
<select id="findUserList" parameterType="cn.itcast.mybatis.po.UserQueryVo"
resultType="cn.itcast.mybatis.po.UserCustom">
SELECT * FROM USER
<!--
where可以自動去掉條件中的第一個and
-->
<where>
<if test="userCustom!=null">
<if test="userCustom.sex!=null and userCustom.sex!=''">
and user.sex = #{userCustom.sex}
</if>
<if test="userCustom.username!=null and userCustom.username!=''">
and user.username LIKE '%${userCustom.username}%'
</if>
</if>
</where>
</select>
<select id="findUserCount" parameterType="cn.itcast.mybatis.po.UserQueryVo" resultType="int">
SELECT count(*) FROM USER
<!--
where可以自動去掉條件中的第一個and
-->
<where>
<if test="userCustom!=null">
<if test="userCustom.sex!=null and userCustom.sex!=''">
and user.sex = #{userCustom.sex}
</if>
<if test="userCustom.username!=null and userCustom.username!=''">
and user.username LIKE '%${userCustom.username}%'
</if>
</if>
</where>
</select>
測試程式碼
//使用者資訊的綜合 查詢
@Test
public void testFindUserList() throws Exception {
SqlSession sqlSession = sqlSessionFactory.openSession();
//建立UserMapper物件,mybatis自動生成mapper代理物件
UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
//建立包裝物件,設定查詢條件
UserQueryVo userQueryVo = new UserQueryVo();
UserCustom userCustom = new UserCustom();
//由於這裡使用動態sql,如果不設定某個值,條件不會拼接在sql中
//userCustom.setSex("1");
userCustom.setUsername("小明");
userQueryVo.setUserCustom(userCustom);
//呼叫userMapper的方法
List<UserCustom> list = userMapper.findUserList(userQueryVo);
System.out.println(list);
}
sql片段
將上邊實現的動態sql判斷程式碼塊抽取出來,組成一個sql片段。其它的statement中就可以引用sql片段。方便程式設計師進行開發。
定義sql片段
<!-- 定義sql片段
id:sql片段的唯 一標識
經驗:是基於單表來定義sql片段,這樣話這個sql片段可重用性才高
在sql片段中不要包括 where
-->
<sql id="query_user_where">
<if test="userCustom!=null">
<if test="userCustom.sex!=null and userCustom.sex!=''">
and user.sex = #{userCustom.sex}
</if>
<if test="userCustom.username!=null and userCustom.username!=''">
and user.username LIKE '%${userCustom.username}%'
</if>
</if>
</sql>
引用sql片段
<!-- 使用者資訊綜合查詢
#{userCustom.sex}:取出pojo包裝物件中性別值
${userCustom.username}:取出pojo包裝物件中使用者名稱稱
-->
<select id="findUserList" parameterType="cn.itcast.mybatis.po.UserQueryVo"
resultType="cn.itcast.mybatis.po.UserCustom">
SELECT * FROM USER
<!--
where可以自動去掉條件中的第一個and
-->
<where>
<!-- 引用sql片段 的id,如果refid指定的id不在本mapper檔案中,需要前邊加namespace -->
<include refid="query_user_where"></include>
<!-- 在這裡還要引用其它的sql片段 -->
</where>
</select>
其中的關鍵是這一句引用:
<!-- 引用sql片段 的id,如果refid指定的id不在本mapper檔案中,需要前邊加namespace -->
<include refid="query_user_where"></include>
foreach
向sql傳遞陣列或List,mybatis使用foreach解析
應用場景
在使用者查詢列表和查詢總數的statement中增加多個id輸入查詢。
類似下面的sql語句:
SELECT * FROM USER WHERE id=1 OR id=10 OR id=16
SELECT * FROM USER WHERE id IN(1,10,16)
在輸入引數型別中新增List ids傳入多個id
public class UserQueryVo {
//傳入多個id
private List<Integer> ids;
修改Mapper.xml
WHERE id=1 OR id=10 OR id=16,在查詢條件中,查詢條件定義成一個sql片段,需要修改sql片段。
<if test="ids!=null">
<!-- 使用 foreach遍歷傳入ids
collection:指定輸入 物件中集合屬性
item:每個遍歷生成物件中
open:開始遍歷時拼接的串
close:結束遍歷時拼接的串
separator:遍歷的兩個物件中需要拼接的串
-->
<!-- 使用實現下邊的sql拼接:
AND (id=1 OR id=10 OR id=16)
-->
<foreach collection="ids" item="user_id" open="AND (" close=")" separator="or">
<!-- 每個遍歷需要拼接的串 -->
id=#{user_id}
</foreach>
測試程式碼
修改上面的測試方法,傳入多個id進行測試。
//建立包裝物件,設定查詢條件
UserQueryVo userQueryVo = new UserQueryVo();
UserCustom userCustom = new UserCustom();
//由於這裡使用動態sql,如果不設定某個值,條件不會拼接在sql中
//userCustom.setSex("1");
userCustom.setUsername("小明");
//傳入多個id
List<Integer> ids = new ArrayList<Integer>();
ids.add(1);
ids.add(10);
ids.add(16);
//將ids通過userQueryVo傳入statement中
userQueryVo.setIds(ids);
userQueryVo.setUserCustom(userCustom);
//呼叫userMapper的方法
List<UserCustom> list = userMapper.findUserList(userQueryVo);
System.out.println(list);
相關文章
- 【MyBatis學習總結 (五),動態SQL】MyBatisSQL
- MyBatis 動態 SQLMyBatisSQL
- mybatis動態SQLMyBatisSQL
- MyBatis(七) 動態SQLMyBatisSQL
- 1 Mybatis動態SQLMyBatisSQL
- Mybatis--動態SQLMyBatisSQL
- mybatis動態sql總結MyBatisSQL
- Mybatis-06 動態SqlMyBatisSQL
- 深入瞭解Mybatis架構設計MyBatis架構
- MyBatis對動態SQL的支援MyBatisSQL
- mybatis動態sql與分頁MyBatisSQL
- Java-Mybatis動態SQL整理JavaMyBatisSQL
- Mybatis介紹之 動態SQLMyBatisSQL
- 深入瞭解 TiDB SQL 優化器TiDBSQL優化
- MyBatis框架之SQL對映和動態SQLMyBatis框架SQL
- 深入淺出MyBatis:「對映器」全瞭解MyBatis
- Mybatis 動態執行SQL語句MyBatisSQL
- 深入淺出MyBatis:反射和動態代理MyBatis反射
- Mybatis where 1=1 動態sql問題MyBatisSQL
- 學習MyBatis必知必會(7)~註解開發、動態SQLMyBatisSQL
- MyBatis 動態 SQL 最全教程,這樣寫 SQL 太優雅了!MyBatisSQL
- MyBatis標籤實現的動態SQL語句MyBatisSQL
- Mybatis(一)Porxy動態代理和sql解析替換MyBatisSQL
- MyBatis系列(七):MyBatis動態Sql之choose,where,set標籤的用法MyBatisSQL
- Mybatis系列全解(八):Mybatis的9大動態SQL標籤你知道幾個?提前致女神!MyBatisSQL
- 深入瞭解原型原型
- 深入瞭解ConcurrentHashMapHashMap
- JavaScript——深入瞭解thisJavaScript
- MyBatis從入門到精通(六):MyBatis動態Sql之if標籤的用法MyBatisSQL
- MyBatis從入門到精通(八):MyBatis動態Sql之foreach標籤的用法MyBatisSQL
- [深入SystemUI]-瞭解recents的啟動流程(一)SystemUI
- MyBatis入門——瞭解配置MyBatis
- 好程式設計師分享MyBatis之動態SQL語句程式設計師MyBatisSQL
- MyBatis進階--介面代理方式實現Dao 和動態SQLMyBatisSQL
- 深入瞭解babel(一)Babel
- [譯] 深入瞭解 FlutterFlutter
- 深入瞭解Synchronized原理synchronized
- 深入瞭解SCN(轉)
- Mybatis 裡對映檔案的動態 SQL 語句,實現if,where,foreache的SQL語句動態拼接查詢MyBatisSQL