<kbd id="afajh"><form id="afajh"></form></kbd>
<strong id="afajh"><dl id="afajh"></dl></strong>
    <del id="afajh"><form id="afajh"></form></del>
        1. <th id="afajh"><progress id="afajh"></progress></th>
          <b id="afajh"><abbr id="afajh"></abbr></b>
          <th id="afajh"><progress id="afajh"></progress></th>

          Mysql4種方式避免重復(fù)插入數(shù)據(jù)!

          共 1750字,需瀏覽 4分鐘

           ·

          2020-10-02 21:48

          點(diǎn)擊上方「藍(lán)字」關(guān)注我們

          最常見的方式就是為字段設(shè)置主鍵或唯一索引,當(dāng)插入重復(fù)數(shù)據(jù)時(shí),拋出錯(cuò)誤,程序終止,但這會給后續(xù)處理帶來麻煩,因此需要對插入語句做特殊處理,盡量避開或忽略異常,下面我簡單介紹一下,感興趣的朋友可以嘗試一下:

          這里為了方便演示,我新建了一個(gè)user測試表,主要有id,username,sex,address這4個(gè)字段,其中主鍵為id(自增),同時(shí)對username字段設(shè)置了唯一索引:

          01 insert ignore into

          即插入數(shù)據(jù)時(shí),如果數(shù)據(jù)存在,則忽略此次插入,前提條件是插入的數(shù)據(jù)字段設(shè)置了主鍵或唯一索引,測試SQL語句如下,當(dāng)插入本條數(shù)據(jù)時(shí),MySQL數(shù)據(jù)庫會首先檢索已有數(shù)據(jù)(也就是idx_username索引),如果存在,則忽略本次插入,如果不存在,則正常插入數(shù)據(jù):

          INSERT?IGNORE?INTO?t_user?(usename,?sex,?address)
          VALUES
          ????(
          ????????'java樂園',
          ????????'male',
          ????????'beijing'
          ????);

          02 on duplicate key update

          即插入數(shù)據(jù)時(shí),如果數(shù)據(jù)存在,則執(zhí)行更新操作,前提條件同上,也是插入的數(shù)據(jù)字段設(shè)置了主鍵或唯一索引,測試SQL語句如下,當(dāng)插入本條記錄時(shí),MySQL數(shù)據(jù)庫會首先檢索已有數(shù)據(jù)(idx_username索引),如果存在,則執(zhí)行update更新操作,如果不存在,則直接插入:

          INSERT?INTO?t_user?(usename,?sex,?address)
          VALUES
          ????(
          ????????'java樂園',
          ????????'male',
          ????????'new?york'
          ????)?ON?DUPLICATE?KEY?UPDATE?sex?=?'male',
          ????address?=?'beijing'

          03 replace into

          即插入數(shù)據(jù)時(shí),如果數(shù)據(jù)存在,則刪除再插入,前提條件同上,插入的數(shù)據(jù)字段需要設(shè)置主鍵或唯一索引,測試SQL語句如下,當(dāng)插入本條記錄時(shí),MySQL數(shù)據(jù)庫會首先檢索已有數(shù)據(jù)(idx_username索引),如果存在,則先刪除舊數(shù)據(jù),然后再插入,如果不存在,則直接插入:

          REPLACE?INTO?t_user?(usename,?sex,?address)
          VALUES
          ????(
          ????????'java樂園',
          ????????'male',
          ????????'new?york'
          ????);

          04 insert if not exists

          即insert into … select … where not exist ... ,這種方式適合于插入的數(shù)據(jù)字段沒有設(shè)置主鍵或唯一索引,當(dāng)插入一條數(shù)據(jù)時(shí),首先判斷MySQL數(shù)據(jù)庫中是否存在這條數(shù)據(jù),如果不存在,則正常插入,如果存在,則忽略:

          INSERT?
          ????INTO?t_user?(usename,?sex,?address)?SELECT
          ????????'java樂園',
          ????????'male',
          ????????'new?york'
          ????FROM
          ????????t_user
          ????WHERE
          ????????NOT?EXISTS?(
          ????????????SELECT
          ????????????????username
          ????????????FROM
          ????????????????t_user
          ????????????WHERE
          ????????????????username?=?'java樂園'
          ????????)

          目前,就分享這4種MySQL處理重復(fù)數(shù)據(jù)的方式吧,前3種方式適合字段設(shè)置了主鍵或唯一索引,最后一種方式則沒有此限制,只要你熟悉一下使用過程,很快就能掌握的,網(wǎng)上也有相關(guān)資料和教程,介紹的非常詳細(xì),感興趣的話,可以搜一下。

          掃碼二維碼

          獲取更多精彩

          Java樂園

          有用!分享+在看?
          瀏覽 37
          點(diǎn)贊
          評論
          收藏
          分享

          手機(jī)掃一掃分享

          分享
          舉報(bào)
          評論
          圖片
          表情
          推薦
          點(diǎn)贊
          評論
          收藏
          分享

          手機(jī)掃一掃分享

          分享
          舉報(bào)
          <kbd id="afajh"><form id="afajh"></form></kbd>
          <strong id="afajh"><dl id="afajh"></dl></strong>
            <del id="afajh"><form id="afajh"></form></del>
                1. <th id="afajh"><progress id="afajh"></progress></th>
                  <b id="afajh"><abbr id="afajh"></abbr></b>
                  <th id="afajh"><progress id="afajh"></progress></th>
                  大香蕉伊人8 | 日本在线成人 | 国产婷婷欧美 | 大香蕉精品在线观看 | 欧美在线24 |