内射老阿姨1区2区3区4区_久久精品人人做人人爽电影蜜月_久久国产精品亚洲77777_99精品又大又爽又粗少妇毛片

MyBatis動態(tài)Sql之if標簽的用法詳解

最近在讀劉增輝老師所著的《MyBatis從入門到精通》一書,很有收獲,于是將自己學習的過程以博客形式輸出,如有錯誤,歡迎指正,如幫助到你,不勝榮幸!

創(chuàng)新互聯(lián)專注為客戶提供全方位的互聯(lián)網綜合服務,包含不限于成都網站設計、成都做網站、外貿網站建設、福綿網絡推廣、微信小程序定制開發(fā)、福綿網絡營銷、福綿企業(yè)策劃、福綿品牌公關、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運營等,從售前售中售后,我們都將竭誠為您服務,您的肯定,是我們最大的嘉獎;創(chuàng)新互聯(lián)為所有大學生創(chuàng)業(yè)者提供福綿建站搭建服務,24小時服務熱線:18980820575,官方網址:m.rwnh.cn

本篇博客主要講解如何使用if標簽生成動態(tài)的Sql,主要包含以下3個場景:

1.根據查詢條件實現(xiàn)動態(tài)查詢
2.根據參數值實現(xiàn)動態(tài)更新某些列
3.根據參數值實現(xiàn)動態(tài)插入某些列

1. 使用if標簽實現(xiàn)動態(tài)查詢

假設有這樣1個需求:根據用戶的輸入條件來查詢用戶列表,如果輸入了用戶名,就根據用戶名模糊查詢,如果輸入了郵箱,就根據郵箱精確查詢,如果同時輸入了用戶名和郵箱,就用這兩個條件去匹配用戶。

首先,我們在接口SysUserMapper中添加如下方法:

/**
 * 根據動態(tài)條件查詢用戶信息
 *
 * @param sysUser
 * @return
 */
List<SysUser> selectByUser(SysUser sysUser);

然后在對應的SysUserMapper.xml中添加如下代碼:

<select id="selectByUser" resultType="com.zwwhnly.mybatisaction.model.SysUser">
  SELECT id,
      user_name,
      user_password,
      user_email,
      create_time
  FROM sys_user
  WHERE 1 = 1
  <if test="userName != null and userName != ''">
    AND user_name LIKE CONCAT('%',#{userName},'%')
  </if>
  <if test="userEmail != null and userEmail != ''">
    AND user_email = #{userEmail}
  </if>
</select>

代碼簡單講解:

1)if標簽的test屬性必填,該屬性值是一個符合OGNL要求的判斷表達式,一般只用true或false作為結果。

2)判斷條件property != null 或 property == null,適用于任何類型的字段,用于判斷屬性值是否為空。

3)判斷條件property != '' 或 property == '',僅適用于String類型的字段,用于判斷是否為空字符串。

4)當有多個判斷條件時,使用and或or進行連接,嵌套的判斷可以使用小括號分組,and相當于Java中的與(&&),or相關于Java中的或(||)。

所以上面代碼的意思就是先判斷字段是否為null,然后再判斷字段是否為空字符串。

最后,在SysUserMapperTest測試類中添加如下測試方法:

@Test
public void testSelectByUser() {
  SqlSession sqlSession = getSqlSession();
  try {
    SysUserMapper sysUserMapper = sqlSession.getMapper(SysUserMapper.class);
    // 只按用戶名查詢
    SysUser query = new SysUser();
    query.setUserName("ad");
    List<SysUser> sysUserList = sysUserMapper.selectByUser(query);
    Assert.assertTrue(sysUserList.size() > 0);
    // 只按郵箱查詢
    query = new SysUser();
    query.setUserEmail("test@mybatis.tk");
    sysUserList = sysUserMapper.selectByUser(query);
    Assert.assertTrue(sysUserList.size() > 0);
    // 同時按用戶民和郵箱查詢
    query = new SysUser();
    query.setUserName("ad");
    query.setUserEmail("test@mybatis.tk");
    sysUserList = sysUserMapper.selectByUser(query);
    // 由于沒有同時符合這兩個條件的用戶,因此查詢結果數為0
    Assert.assertTrue(sysUserList.size() == 0);
  } finally {
    sqlSession.close();
  }
}

運行測試代碼,測試通過,輸出日志如下:

DEBUG [main] - ==> Preparing: SELECT id, user_name, user_password, user_email, create_time FROM sys_user WHERE 1 = 1 AND user_name LIKE CONCAT('%',?,'%')
DEBUG [main] - ==> Parameters: ad(String)
TRACE [main] - <== Columns: id, user_name, user_password, user_email, create_time
TRACE [main] - <== Row: 1, admin, 123456, admin@mybatis.tk, 2019-06-27 18:21:07.0
DEBUG [main] - <== Total: 1
DEBUG [main] - ==> Preparing: SELECT id, user_name, user_password, user_email, create_time FROM sys_user WHERE 1 = 1 AND user_email = ?
DEBUG [main] - ==> Parameters: test@mybatis.tk(String)
TRACE [main] - <== Columns: id, user_name, user_password, user_email, create_time
TRACE [main] - <== Row: 1001, test, 123456, test@mybatis.tk, 2019-06-27 18:21:07.0
DEBUG [main] - <== Total: 1
DEBUG [main] - ==> Preparing: SELECT id, user_name, user_password, user_email, create_time FROM sys_user WHERE 1 = 1 AND user_name LIKE CONCAT('%',?,'%') AND user_email = ?
DEBUG [main] - ==> Parameters: ad(String), test@mybatis.tk(String)
DEBUG [main] - <== Total: 0

2. 使用if標簽實現(xiàn)動態(tài)更新

假設有這樣1個需求:更新用戶信息的時候不能將原來有值但沒有發(fā)生變化的字段更新為空或null,即只更新有值的字段。

首先,我們在接口SysUserMapper中添加如下方法:

/**
 * 根據主鍵選擇性更新用戶信息
 *
 * @param sysUser
 * @return
 */
int updateByIdSelective(SysUser sysUser);

然后在對應的SysUserMapper.xml中添加如下代碼:

<update id="updateByIdSelective">
  UPDATE sys_user
  SET
  <if test="userName != null and userName != ''">
    user_name = #{userName},
  </if>
  <if test="userPassword != null and userPassword != ''">
    user_password = #{userPassword},
  </if>
  <if test="userEmail != null and userEmail != ''">
    user_email = #{userEmail},
  </if>
  <if test="userInfo != null and userInfo != ''">
    user_info = #{userInfo},
  </if>
  <if test="headImg != null">
    head_img = #{headImg,jdbcType=BLOB},
  </if>
  <if test="createTime != null">
    create_time = #{createTime,jdbcType=TIMESTAMP},
  </if>
  id = #{id}
  WHERE id = #{id}
</update>

最后,在SysUserMapperTest測試類中添加如下測試方法:

@Test
public void testUpdateByIdSelective() {
  SqlSession sqlSession = getSqlSession();
  try {
    SysUserMapper sysUserMapper = sqlSession.getMapper(SysUserMapper.class);
    SysUser sysUser = new SysUser();
    // 更新id=1的用戶
    sysUser.setId(1L);
    // 修改郵箱
    sysUser.setUserEmail("test@mybatis.tk");
    int result = sysUserMapper.updateByIdSelective(sysUser);
    Assert.assertEquals(1, result);
    // 查詢id=1的用戶
    sysUser = sysUserMapper.selectById(1L);
    // 修改后的名字保持不變,但是郵箱變成了新的
    Assert.assertEquals("admin", sysUser.getUserName());
    Assert.assertEquals("test@mybatis.tk", sysUser.getUserEmail());
  } finally {
    sqlSession.close();
  }
}

運行測試代碼,測試通過,輸出日志如下:

DEBUG [main] - ==> Preparing: UPDATE sys_user SET user_email = ?, id = ? WHERE id = ?
DEBUG [main] - ==> Parameters: test@mybatis.tk(String), 1(Long), 1(Long)
DEBUG [main] - <== Updates: 1
DEBUG [main] - ==> Preparing: SELECT id, user_name, user_password, user_email, create_time FROM sys_user WHERE id = ?
DEBUG [main] - ==> Parameters: 1(Long)
TRACE [main] - <== Columns: id, user_name, user_password, user_email, create_time
TRACE [main] - <== Row: 1, admin, 123456, test@mybatis.tk, 2019-06-27 18:21:07.0
DEBUG [main] - <== Total: 1

3. 使用if標簽實現(xiàn)動態(tài)插入

假設有這樣1個需求:往數據庫表中插入數據的時候,如果某一列的參數值不為空,就使用傳入的值,如果傳入的參數值為空,就使用數據庫中的默認值(通常是空),而不使用傳入的空值。

為了更好的理解該示例,我們先給sys_user表的user_email字段設置默認值:test@mybatis.tk,Sql語句如下:

ALTER TABLE sys_user
MODIFY COLUMN user_email VARCHAR(50) NULL DEFAULT 'test@mybatis.tk'
COMMENT '郵箱'
AFTER user_password;

首先,我們在接口SysUserMapper中添加如下方法:

/**
 * 根據傳入的參數值動態(tài)插入列
 *
 * @param sysUser
 * @return
 */
int insertSelective(SysUser sysUser);

然后在對應的SysUserMapper.xml中添加如下代碼:

<insert id="insertSelective" useGeneratedKeys="true" keyProperty="id">
  INSERT INTO sys_user(user_name, user_password,
  <if test="userEmail != null and userEmail != ''">
    user_email,
  </if>
  user_info, head_img, create_time)
  VALUES (#{userName},#{userPassword},
  <if test="userEmail != null and userEmail != ''">
    #{userEmail},
  </if>
  #{userInfo},#{headImg,jdbcType=BLOB},#{createTime,jdbcType=TIMESTAMP})
</insert>

最后,在SysUserMapperTest測試類中添加如下測試方法:

@Test
public void testInsertSelective() {
  SqlSession sqlSession = getSqlSession();
  try {
    SysUserMapper sysUserMapper = sqlSession.getMapper(SysUserMapper.class);
    SysUser sysUser = new SysUser();
    sysUser.setUserName("test-selective");
    sysUser.setUserPassword("123456");
    sysUser.setUserInfo("test info");
    sysUser.setCreateTime(new Date());
    sysUserMapper.insertSelective(sysUser);
    // 獲取剛剛插入的數據
    sysUser = sysUserMapper.selectById(sysUser.getId());
    // 因為沒有指定userEmail,所以用的是數據庫的默認值
    Assert.assertEquals("test@mybatis.tk", sysUser.getUserEmail());
  } finally {
    sqlSession.close();
  }
}

運行測試代碼,測試通過,輸出日志如下:

DEBUG [main] - ==> Preparing: INSERT INTO sys_user(user_name, user_password, user_info, head_img, create_time) VALUES (?,?, ?,?,?)
DEBUG [main] - ==> Parameters: test-selective(String), 123456(String), test info(String), null, 2019-07-08 11:40:36.927(Timestamp)
DEBUG [main] - <== Updates: 1
DEBUG [main] - ==> Preparing: SELECT id, user_name, user_password, user_email, create_time FROM sys_user WHERE id = ?
DEBUG [main] - ==> Parameters: 1021(Long)
TRACE [main] - <== Columns: id, user_name, user_password, user_email, create_time
TRACE [main] - <== Row: 1021, test-selective, 123456, test@mybatis.tk, 2019-07-08 11:40:37.0
DEBUG [main] - <== Total: 1

4. 源碼

源碼地址:https://github.com/zwwhnly/mybatis-action.git,歡迎下載。

總結

以上所述是小編給大家介紹的MyBatis動態(tài)Sql之if標簽的用法詳解 ,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對創(chuàng)新互聯(lián)網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

新聞名稱:MyBatis動態(tài)Sql之if標簽的用法詳解
網址分享:http://m.rwnh.cn/article44/jejcee.html

成都網站建設公司_創(chuàng)新互聯(lián),為您提供網站導航、云服務器、網站設計公司、用戶體驗、全網營銷推廣

廣告

聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

外貿網站制作
香格里拉县| 嵊州市| 建德市| 利辛县| 常德市| 双桥区| 上高县| 武穴市| 盐城市| 三门峡市| 保康县| 梅州市| 南皮县| 汤原县| 长垣县| 南安市| 洛阳市| 钟山县| 清新县| 屯昌县| 潼南县| 钟山县| 汉中市| 阳新县| 双辽市| 红河县| 广德县| 咸宁市| 和顺县| 砚山县| 浑源县| 天水市| 贵州省| 乐清市| 达日县| 新民市| 垫江县| 遵化市| 香格里拉县| 定襄县| 四子王旗|