"

齐发游戏app_官方网站拥有全球最顶尖的原生APP,每天为您提供千场精彩体育赛事,齐发游戏app_官方网站更有真人、彩票、电子老虎机、真人电子竞技游戏等多种娱乐方式选择,齐发游戏app_官方网站让您尽享娱乐、赛事投注等,且无后顾之忧!

  • <nav id="seiua"></nav>
  • <menu id="seiua"><strong id="seiua"></strong></menu>
  • "

    Mysql 4種方式避免重復插入數據!

    小編:啊南 87閱讀 2020.11.20

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

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

    01 insert ignore into

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

    02 on duplicate key update

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

    03 replace into

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

    04 insert if not exists

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

    目前,就分享這4種MySQL處理重復數據的方式吧,前3種方式適合字段設置了主鍵或唯一索引,最后一種方式則沒有此限制,只要你熟悉一下使用過程,很快就能掌握的

    關聯標簽:
    齐发游戏app_官方网站
  • <nav id="seiua"></nav>
  • <menu id="seiua"><strong id="seiua"></strong></menu>