最美情侣中文字幕电影,在线麻豆精品传媒,在线网站高清黄,久久黄色视频

歡迎光臨散文網(wǎng) 會(huì)員登陸 & 注冊

避免 MySQL 插入重復(fù)數(shù)據(jù)的 4 種方式

2023-01-26 18:13 作者:要寵你上天  | 我要投稿

避免 MySQL 插入重復(fù)數(shù)據(jù)最常見的方式就是為字段設(shè)置主鍵或唯一索引,當(dāng)插入重復(fù)數(shù)據(jù)時(shí),拋出錯(cuò)誤,程序終止,但這會(huì)給后續(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ù)庫會(huì)首先檢索已有數(shù)據(jù)(也就是idx_username索引),如果存在,則忽略本次插入,如果不存在,則正常插入數(shù)據(jù):

02 on duplicate key update

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

03 replace into

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

04 insert if not exists

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

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


避免 MySQL 插入重復(fù)數(shù)據(jù)的 4 種方式的評論 (共 條)

分享到微博請遵守國家法律
大邑县| 波密县| 巢湖市| 喀喇沁旗| 惠东县| 黑山县| 贵德县| 栖霞市| 辉县市| 安溪县| 图们市| 博野县| 西乡县| 汶川县| 栾川县| 桐庐县| 同江市| 巢湖市| 吉木乃县| 措美县| 阳春市| 南京市| 饶平县| 儋州市| 小金县| 酉阳| 临湘市| 钟祥市| 黄骅市| 都匀市| 枣强县| 朝阳市| 三都| 马公市| 泰兴市| 铜陵市| 额敏县| 多伦县| 垣曲县| 布尔津县| 讷河市|