<kbd id="5sdj3"></kbd>
<th id="5sdj3"></th>

  • <dd id="5sdj3"><form id="5sdj3"></form></dd>
    <td id="5sdj3"><form id="5sdj3"><big id="5sdj3"></big></form></td><del id="5sdj3"></del>

  • <dd id="5sdj3"></dd>
    <dfn id="5sdj3"></dfn>
  • <th id="5sdj3"></th>
    <tfoot id="5sdj3"><menuitem id="5sdj3"></menuitem></tfoot>

  • <td id="5sdj3"><form id="5sdj3"><menu id="5sdj3"></menu></form></td>
  • <kbd id="5sdj3"><form id="5sdj3"></form></kbd>

    【嚴肅警告】通報全體,公司沒有午休這件事,從未有過,誰在中午午休立刻走人,沒有下次!

    共 3857字,需瀏覽 8分鐘

     ·

    2024-05-23 16:00

    點擊關(guān)注公眾號,SQL干貨及時獲取

    后臺回復(fù):1024,獲取海量學(xué)習(xí)資源
    SQL刷題專欄
    SQL145題系列

    今天看到個奇葩帖,內(nèi)容如下:

    這類奇葩公司不知大家是否遇到過,反正我是真沒見過。

    以往待過的公司,也一直執(zhí)行著:“中午不睡!下午崩潰!”的理念。

    午休這真的是太正常的需求了。

    要說真遇到項目緊急需要支持時,我相信幾乎所有員工都是可以接受的。

    但要說“誰在午休立刻走人,沒有下次!”,我還從未見過如此XXXX之人!

    這樣的公司,想想就知道根本留不住人。

    稍微技術(shù)好點的,能換一家公司的,誰還會在這地方受氣呢?


    以下是今天的SQL干貨

    今天給大家介紹一下遇到大批量插入的時候,如何去除重復(fù)數(shù)據(jù)。

    測試數(shù)據(jù)

    CREATE TABLE `animal` (
      `id` int(11) NOT NULL AUTO_INCREMENT,
      `name` varchar(20) DEFAULT NULL,
      `age` int(11) DEFAULT NULL,
      PRIMARY KEY (`id`)
    );


    INSERT INTO `pilipa_dds`.`student` (`id`, `name`, `age`) VALUES ('1', 'cat', '12');
    INSERT INTO `pilipa_dds`.`student` (`id`, `name`, `age`) VALUES ('2', 'dog', '13');
    INSERT INTO `pilipa_dds`.`student` (`id`, `name`, `age`) VALUES ('3', 'camel', '25');
    INSERT INTO `pilipa_dds`.`student` (`id`, `name`, `age`) VALUES ('4', 'cat', '32');
    INSERT INTO `pilipa_dds`.`student` (`id`, `name`, `age`) VALUES ('5', 'dog', '42');

    目標

    去掉name重復(fù)的數(shù)據(jù)。

    先篩選出重復(fù)數(shù)據(jù)

    SELECT name,count( 1 ) 
    FROM
     student
    GROUP BY
    NAME 
    HAVING
    count( 1 ) > 1;

     

    輸出:

    name count(1)
    cat 2
    dog 2

    name為cat和dog的數(shù)據(jù)重復(fù)了,每個重復(fù)的數(shù)據(jù)有兩條;

    刪除全部重復(fù)數(shù)據(jù),一條不留

    直接刪除會報錯

    DELETE 
    FROM
     student
    WHERE
     NAME IN (
     SELECT NAME 
     FROM
      student
     GROUP BY
     NAME 
    HAVING
    count( 1 ) > 1)

    報錯:1093 - You can't specify target table 'student' for update in FROM clause, Time: 0.016000s

    原因是:更新這個表的同時又查詢了這個表,查詢這個表的同時又去更新了這個表,可以理解為死鎖。mysql不支持這種更新查詢同一張表的操作

    解決辦法:把要更新的幾列數(shù)據(jù)查詢出來做為一個第三方表,然后篩選更新。

    DELETE 
    FROM
     student
    WHERE
     NAME IN (
     SELECT
      t.NAME
    FROM
     ( SELECT NAME 
    FROM student
    GROUP BY NAME 
    HAVING count( 1 ) > 1 
    ) t
    )

    刪除表中刪除重復(fù)數(shù)據(jù),僅保留一條 在刪除之前,我們可以先查一下,我們要刪除的重復(fù)數(shù)據(jù)是啥樣的

    SELECT
     *
    FROM
     student
    WHERE
     id NOT IN (
     SELECT
      t.id
     FROM
     ( SELECT MIN( id ) AS id FROM student GROUP BY `name` ) t
     )

    啥意思呢,就是先通過name分組,查出id最小的數(shù)據(jù),這些數(shù)據(jù)就是我們要留下的火種,那么再查詢出id不在這里面的,就是我們要刪除的重復(fù)數(shù)據(jù)。

    開始刪除重復(fù)數(shù)據(jù),僅留一條 很簡單,剛才的select換成delete即可

    DELETE 
    FROM
     student
    WHERE
     id NOT IN (
     SELECT
      t.id
     FROM
     ( SELECT MIN( id ) AS id FROM student GROUP BY `name` ) t
     )


        

    最后給大家分享我寫的SQL兩件套:《SQL基礎(chǔ)知識第二版》《SQL高級知識第二版》的PDF電子版。里面有各個語法的解釋、大量的實例講解和批注等等,非常通俗易懂,方便大家跟著一起來實操。


    有需要的讀者可以下載學(xué)習(xí),在下面的公眾號「數(shù)據(jù)前線」(非本號)后臺回復(fù)關(guān)鍵字:SQL,就行

    數(shù)據(jù)前線
    ——End——

           
    后臺回復(fù)關(guān)鍵字:1024,獲取一份精心整理的技術(shù)干貨
    后臺回復(fù)關(guān)鍵字:進群,帶你進入高手如云的交流群。

               
    推薦閱讀
                  
                  

    瀏覽 486
    1點贊
    評論
    收藏
    分享

    手機掃一掃分享

    分享
    舉報
    評論
    圖片
    表情
    推薦
    1點贊
    評論
    收藏
    分享

    手機掃一掃分享

    分享
    舉報

    <kbd id="5sdj3"></kbd>
    <th id="5sdj3"></th>

  • <dd id="5sdj3"><form id="5sdj3"></form></dd>
    <td id="5sdj3"><form id="5sdj3"><big id="5sdj3"></big></form></td><del id="5sdj3"></del>

  • <dd id="5sdj3"></dd>
    <dfn id="5sdj3"></dfn>
  • <th id="5sdj3"></th>
    <tfoot id="5sdj3"><menuitem id="5sdj3"></menuitem></tfoot>

  • <td id="5sdj3"><form id="5sdj3"><menu id="5sdj3"></menu></form></td>
  • <kbd id="5sdj3"><form id="5sdj3"></form></kbd>
    逼操网| 国产成人视频在线 | 日韩免费中文字幕 | 国产玖玖在线 | 天天拍,天天射,天天撸 |