中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

mysql中有哪些批量操作語句

發布時間:2021-07-13 15:44:24 來源:億速云 閱讀:247 作者:Leah 欄目:大數據

這篇文章將為大家詳細講解有關mysql中有哪些批量操作語句,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。


1、.replace into 批量更新

   replace into t_student(id,dr) values (1,'2'),(2,'3'),...(x,'y');
   

例子

        replace into t_student

            (`Id`,`Author`,`CreatedTime`,`UpdatedTime`)

         values 

            (1,'王五','2016-12-12 12:20','2016-12-12 12:20'),

            (2,'張三','2016-12-12 12:20','2016-12-12 12:20');

2、insert into ...on duplicate key update批量更新

  insert into t_student(id,dr) values (1,'2'),(2,'3'),...(x,'y') on duplicate key update dr=values(dr);

  例子

    insert into t_student

        (`Id`,`Author`,`CreatedTime`,`UpdatedTime`) 

    values 

        (1,'張三','2017-12-12 12:20','2017-12-12 12:20'),

        (2,'王五','2017-12-12 12:20','2017-12-12 12:20') 

    on duplicate key update 

         Author=values(Author),

         CreatedTime=values(CreatedTime),

         UpdatedTime=values(UpdatedTime);

replace into  和 insert into on duplicate key update的不同在于:

      replace into 操作本質是對重復的記錄先delete 后insert,如果更新的字段不全會將缺失的字段置為缺省值,用這個要悠著點否則不小心清空大量數據可不是鬧著玩的。
       insert into 則是只update重復記錄,不會改變其它字段。

3.創建臨時表,先更新臨時表,然后從臨時表中update

    create temporary table tmp(

        id int(4) primary key,

        dr varchar(50)

   );


    insert into tmp values  (0,'gone'), (1,'xx'),...(m,'yy');


    update 

            t_student, tmp 

    set 

            t_student.dr=tmp.dr 

     where 

           t_student.id=tmp.id;

   注意:這種方法需要用戶有temporary 表的create 權限。

4、使用mysql 自帶的語句構建批量更新

    mysql 實現批量 可以用點小技巧來實現:

    UPDATE t_stuent
        SET name= CASE id 
            WHEN 1 THEN '趙六' 
            WHEN 2 THEN '馬三'
            WHEN 3 THEN '王五'
        END
    WHERE id IN (1,2,3)

    這句sql 的意思是,更新dingdan 字段,如果id=1 則dingdan 的值為3,如果id=2 則dingdan 的值為4……
    where部分不影響代碼的執行,但是會提高sql執行的效率。確保sql語句僅執行需要修改的行數,這里只有3條數據進行更新,而where子句確保只有3行數據執行。   

    例子:UPDATE t_student
        SET Author = CASE id 
            WHEN 1 THEN '黃飛鴻' 
            WHEN 2 THEN '方世玉'
            WHEN 3 THEN '洪熙官'
        END
    WHERE id IN (1,2,3)

    如果更新多個值的話,只需要稍加修改:

    UPDATE categories
        SET dingdan = CASE id 
            WHEN 1 THEN 3 
            WHEN 2 THEN 4 
            WHEN 3 THEN 5 
        END, 
        title = CASE id 
            WHEN 1 THEN 'New Title 1'
            WHEN 2 THEN 'New Title 2'
            WHEN 3 THEN 'New Title 3'
        END
    WHERE id IN (1,2,3)

   例子:UPDATE book
        SET Author = CASE id 
            WHEN 1 THEN '黃飛鴻2' 
            WHEN 2 THEN '方世玉2'
            WHEN 3 THEN '洪熙官2'
        END,
        Code = CASE id 
            WHEN 1 THEN 'HFH2' 
            WHEN 2 THEN 'FSY2'
            WHEN 3 THEN 'HXG2'
        END
    WHERE id IN (1,2,3)


關于mysql中有哪些批量操作語句就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

蒙自县| 自治县| 秭归县| 读书| 嘉荫县| 义马市| 桂平市| 顺平县| 鄂托克旗| 太湖县| 长宁区| 托克托县| 喀喇| 鄱阳县| 蒲江县| 卢龙县| 冷水江市| 丰原市| 绥化市| 城口县| 西宁市| 交口县| 麻城市| 布拖县| 龙里县| 永靖县| 融水| 崇信县| 和硕县| 华坪县| 百色市| 嘉兴市| 响水县| 恭城| 安仁县| 栖霞市| 河北省| 合水县| 通州市| 天峻县| 富蕴县|