欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mysql中update按照多重條件進(jìn)行更新處理的方案

 更新時間:2022年09月09日 16:23:54   作者:賣柴火的小伙子  
更新數(shù)據(jù)是使用數(shù)據(jù)庫時最重要的任務(wù)之一,下面這篇文章主要給大家介紹了關(guān)于mysql中update按照多重條件進(jìn)行更新處理的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下

1.場景問題說明

mysql中一般的update寫法支持的方式是,update 表 set 字段名=修改后的字段值 where 條件1 and 條件2 and 其他條件;如果現(xiàn)在需求是對滿足where后面的條件基礎(chǔ)之上需對滿足指定的條件數(shù)據(jù)再進(jìn)行不同更新處理,那應(yīng)該如何處理?如果有這樣的疑問或是遇到此類場景請繼續(xù)往下看.

還原一下我遇到的業(yè)務(wù)場景:現(xiàn)有一批會員卡,會員卡類型有次數(shù)卡和期限卡之分,期限卡余額為每天扣除一天,次數(shù)卡余額不隨時間進(jìn)行變化,只有使用之后才會扣除?,F(xiàn)需要對會員卡進(jìn)行更新截止時間的操作,其中只需要對期限卡更新余額操作。主要問題的難點(diǎn)在于會員卡類型為期限卡的會員卡,不僅需要更新有效截止時間,還需要更新會員卡的余額。為方便說明問題,簡化業(yè)務(wù)如下:將會員卡id為1、2、3的截止日期更新為2022-05-01 22:50:59,其中期限卡余額更新為11.次數(shù)卡余額不做處理(會員卡id為1和2為期限卡,3為次數(shù)卡)。

會員卡表信息:

2.處理方案

2.1 使用update case when

sql如下:

UPDATE staff_card SET end_time="2022-05-01 22:50:59",update_time=NOW(),
rest_count=(CASE WHEN card_type=1 THEN 11 ELSE rest_count END) WHERE id IN  (1,2,3)

配置文件寫法:

 <update id="updateRestCount" >
           UPDATE staff_card
            <set>
            end_time="2022-05-01 22:50:59",update_time=NOW(),
rest_count=(CASE WHEN card_type=1 THEN 11 ELSE rest_count END)
           </set> 
            WHERE id IN  
            ( 
				<foreach collection="cardIds" item="cardId">
					#{cardId}
				</foreach>
			)  
    </update>

注意寫法:只對于期限卡才更新余額,次數(shù)卡余額不更新,也就是次數(shù)卡的余額rest_count字段不進(jìn)行更新,直接寫ELSE rest_count,如果次數(shù)卡余額更新為其他金額,則ELSE 后面寫具體的余額值.

2.2 使用if標(biāo)簽

組裝會員卡列表信息,將每個會員卡的卡類型進(jìn)行設(shè)置

  ArrayList<CardInfo> cardList= new ArrayList<>();
        CardInfo cardInfo = new CardInfo();
        // 設(shè)置會員卡id
        cardInfo.setId(1);
        // 設(shè)置會員卡類型:1.期限卡;2.次數(shù)卡
        cardInfo.setCardType(1);
        CardInfo cardInfo2 = new CardInfo();
        cardInfo2.setId(2);
        cardInfo2.setCardType(1);
        CardInfo cardInfo3 = new CardInfo();
        cardInfo3.setId(3);
        cardInfo3.setCardType(2);
        cardList.add(cardInfo);
        cardList.add(cardInfo2);
        cardList.add(cardInfo3);

mapper接口:

public interface CardMapper {
    // 更新會員卡信息
    void updateRestCount(@Param("cardList") List<CardInfo> cardInfos);
}

配置文件:

 <update id="updateRestCount" >
        <foreach collection="cardList" item="card">
            UPDATE staff_card
            <set>
               end_time="2022-05-01 22:50:59",update_time=NOW(),
                <if test="card.cardType == 1">
                    rest_count =11
                </if>
            </set>
            WHERE id=#{card.id};
        </foreach>
    </update>

總結(jié)

到此這篇關(guān)于mysql中update按照多重條件進(jìn)行更新處理的文章就介紹到這了,更多相關(guān)mysql update按多重條件更新內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • MySQL如何實(shí)現(xiàn)事務(wù)的ACID

    MySQL如何實(shí)現(xiàn)事務(wù)的ACID

    這篇文章主要介紹了MySQL如何實(shí)現(xiàn)事務(wù)的四大特性,幫助大家更好的理解和學(xué)習(xí)MySQL數(shù)據(jù)庫,感興趣的朋友可以了解下
    2020-09-09
  • 一文掌握MySQL唯一索引是如何加鎖的

    一文掌握MySQL唯一索引是如何加鎖的

    這篇文章主要介紹了一文掌握MySQL唯一索引是如何加鎖的,本案例其實(shí)就是在主鍵索引上進(jìn)行等值查詢,取決于查詢記錄是否存在,存在退化成記錄鎖,否則就是在索引樹中找到第一個大于該查詢記錄的記錄后,將改記錄的索引中的next-key lock退換成間隙鎖,需要的朋友可以參考下
    2024-06-06
  • MySQL之DATE_ADD()和DATE_SUB()函數(shù)的使用方式

    MySQL之DATE_ADD()和DATE_SUB()函數(shù)的使用方式

    這篇文章主要介紹了MySQL之DATE_ADD()和DATE_SUB()函數(shù)的使用方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-04-04
  • Oracle與MySQL的區(qū)別詳解

    Oracle與MySQL的區(qū)別詳解

    MySQL和Oracle Database都是一個關(guān)系型數(shù)據(jù)庫管理系統(tǒng),本文主要介紹了MySQL和Oracle Database的區(qū)別及優(yōu)缺點(diǎn)是什么,感興趣的小伙伴歡迎閱讀
    2023-04-04
  • 簡單了解標(biāo)準(zhǔn)SQL的update語句三種用法

    簡單了解標(biāo)準(zhǔn)SQL的update語句三種用法

    這篇文章主要介紹了簡單了解標(biāo)準(zhǔn)SQL的update語句三種用法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,,需要的朋友可以參考下
    2019-06-06
  • 深入了解mysql長事務(wù)

    深入了解mysql長事務(wù)

    這篇文章主要介紹了mysql長事務(wù)的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)mysql,感興趣的朋友可以了解下
    2020-08-08
  • MySQL數(shù)據(jù)庫優(yōu)化的六種方式總結(jié)

    MySQL數(shù)據(jù)庫優(yōu)化的六種方式總結(jié)

    關(guān)于數(shù)據(jù)庫優(yōu)化,網(wǎng)上有不少資料和方法,但是不少質(zhì)量參差不齊,所以下面這篇文章主要給大家介紹了關(guān)于MySQL數(shù)據(jù)庫優(yōu)化的六種方式,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-01-01
  • 怎樣正確創(chuàng)建MySQL索引的方法詳解

    怎樣正確創(chuàng)建MySQL索引的方法詳解

    今天小編就為大家分享一篇關(guān)于怎樣正確創(chuàng)建MySQL索引的方法詳解,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-03-03
  • CentOS 6.5下yum安裝 MySQL-5.5全過程圖文教程

    CentOS 6.5下yum安裝 MySQL-5.5全過程圖文教程

    在linux安裝mysql是一個困難的事情,yum安裝一般是安裝的mysql5.1,現(xiàn)在經(jīng)過自己不懈努力終于能用yum安裝mysql5.5了。下面通過兩種方法給大家介紹CentOS 6.5下yum安裝 MySQL-5.5全過程,一起學(xué)習(xí)吧
    2016-05-05
  • MySQL中關(guān)于null值的一個小問題

    MySQL中關(guān)于null值的一個小問題

    這篇文章主要介紹了MySQL中關(guān)于null值的一個小問題,幫助大家更好的理解和學(xué)習(xí)使用MySQL,感興趣的朋友可以了解下
    2021-03-03

最新評論