日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

Spring+SpringMVC+MyBatis深入学习及搭建(五)——动态sql

發布時間:2025/3/17 javascript 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Spring+SpringMVC+MyBatis深入学习及搭建(五)——动态sql 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

mybatis核心:對sql語句進行靈活操作,通過表達式進行判斷,對sql進行靈活拼接、組裝。

mybatis提供各種標簽方法實現動態拼接sql。

1. if&where

1.2 需求

用戶信息綜合查詢列表和用戶信息查詢列表總數這兩個statement的定義使用動態sql。

對查詢條件進行判斷,如果輸入參數不為空才進行查詢條件拼接。

1.3 mapper.xml

<select id="findUserList" parameterType="joanna.yan.mybatis.entity.UserQueryVo" resultType="joanna.yan.mybatis.entity.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="joanna.yan.mybatis.entity.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>

1.4測試代碼

@Testpublic void findUserListTest() throws Exception{SqlSession sqlSession=sqlSessionFactory.openSession();UserMapper userMapper=sqlSession.getMapper(UserMapper.class);//創建包裝對象,設置查詢條件UserQueryVo userQueryVo=new UserQueryVo();UserCustom userCustom=new UserCustom();//由于這里使用動態sql,如果不設置某個值,條件不會拼接在sql中 // userCustom.setSex("1");userCustom.setUsername("張三豐");userQueryVo.setUserCustom(userCustom);List<UserCustom> list=userMapper.findUserList(userQueryVo);System.out.println(list);}

打印的sql:如果不設置sex的值,條件不會拼接在sql中

2.sql片段

2.1 需求

將上邊實現的動態sql判斷代碼塊抽取出來,組成一個sql片段。其它的statement中就可以引用sql片段。方便程序員進行開發。

2.2 定義sql片段

<!--定義sql片段id:sql片段的唯一標識經驗:1.是基于單表來定義sql片段的,這樣的話這個sql片段可重用性才高2.在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>

2.3 引用sql片段

在mapper.xml中定義statement中引用sql片段:

<select id="findUserList" parameterType="joanna.yan.mybatis.entity.UserQueryVo" resultType="joanna.yan.mybatis.entity.UserCustom">SELECT * FROM USER<!--where可以自動去掉條件中的第一個and --><where><!--引用sql片段的id,如果refid指定的id不在本mapper文件中,需要在前邊加namespace --><include refid="query_user_where"></include><!--在這里還可以引用其它的sql片段 --></where></select><select id="findUserCount" parameterType="joanna.yan.mybatis.entity.UserQueryVo" resultType="int">SELECT count(*) FROM USER <!--where可以自動去掉條件中的第一個and --><where><!--引用sql片段的id,如果refid指定的id不在本mapper文件中,需要在前邊加namespace --><include refid="query_user_where"></include><!--在這里還可以引用其它的sql片段 --></where></select>

3. foreach

向sql傳遞數組或List,mybatis使用foreach解析。

3.1 需求

在用戶查詢列表和查詢總數的statement中增加多個id輸入查詢。

sql語句如下,兩種方法:

SELECT * FROM USER WHERE id=1 OR id=10 OR id=16

SELECT * FROM USER WHERE id IN(1,10,16)

3.2 在輸入參數類型中添加List<Integer> ids傳入多個id

3.3 修改mapper.xml

WHERE id=1 OR id=10 OR id=16

在前面的查詢條件中,查詢條件定義成了一個sql片段,現在我們需要修改sql片段。

<!--定義sql片段id:sql片段的唯一標識經驗:1.是基于單表來定義sql片段的,這樣的話這個sql片段可重用性才高2.在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 test="ids!=null"><!--使用foreach遍歷傳入的idscollection:指定輸入對象中集合屬性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></if></if></sql>

3.4 測試代碼

@Testpublic void findUserListTest() throws Exception{SqlSession sqlSession=sqlSessionFactory.openSession();UserMapper userMapper=sqlSession.getMapper(UserMapper.class);//創建包裝對象,設置查詢條件UserQueryVo userQueryVo=new UserQueryVo();UserCustom userCustom=new UserCustom();//由于這里使用動態sql,如果不設置某個值,條件不會拼接在sql中 // userCustom.setSex("1");userCustom.setUsername("小明");//傳入多個idList<Integer> ids=new ArrayList<>();ids.add(1);ids.add(10);ids.add(16);userQueryVo.setIds(ids);userQueryVo.setUserCustom(userCustom);List<UserCustom> list=userMapper.findUserList(userQueryVo);System.out.println(list);}

?

轉載自?http://www.cnblogs.com/Joanna-Yan/p/6908763.html

總結

以上是生活随笔為你收集整理的Spring+SpringMVC+MyBatis深入学习及搭建(五)——动态sql的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。