亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MySql批量插入時如何不重復插入數(shù)據(jù)

 更新時間:2021年06月22日 10:23:26   作者:DT辰白  
Mysql插入不重復的數(shù)據(jù),當大數(shù)據(jù)量的數(shù)據(jù)需要插入值時,要判斷插入是否重復,然后再插入,那么如何提高效率,本文就詳細的介紹一下,感興趣的可以了解一下

前言

Mysql插入不重復的數(shù)據(jù),當大數(shù)據(jù)量的數(shù)據(jù)需要插入值時,要判斷插入是否重復,然后再插入,那么如何提高效率?解決的辦法有很多種,不同的場景解決方案也不一樣,數(shù)據(jù)量很小的情況下,怎么搞都行,但是數(shù)據(jù)量很大的時候,這就不是一個簡單的問題了。

一、insert ignore into

會忽略數(shù)據(jù)庫中已經(jīng)存在 的數(shù)據(jù),如果數(shù)據(jù)庫沒有數(shù)據(jù),就插入新的數(shù)據(jù),如果有數(shù)據(jù)的話就跳過當前插入的這條數(shù)據(jù)。這樣就可以保留數(shù)據(jù)庫中已經(jīng)存在數(shù)據(jù),達到在間隙中插入數(shù)據(jù)的目的。

控制器方法:

/**
 * 插入員工數(shù)據(jù)
 */
@PostMapping("save")
@ResponseBody
public CommonResult<Employee> save(@RequestBody Employee employee){
    return employeeService.saveEmp(employee);
}
INSERT INTO 插入數(shù)據(jù)
<!--插入員工數(shù)據(jù)-->
<insert id="saveEmp" parameterType="com.dt.springbootdemo.entity.Employee">
    INSERT INTO t_employee(id, name, age, salary, department_id)
    VALUES (#{id},#{name},#{age},#{salary},#{departmentId})
</insert>

在這里插入圖片描述

我們新增一條主鍵ID為1的員工記錄。

當我再發(fā)送一次請求的時候,會報SQL語句執(zhí)行錯誤,因為主鍵唯一,并且ID=1的記錄已經(jīng)存在了。

在這里插入圖片描述

加上ignore,再次添加一條ID=1的員工記錄

INSERT IGNORE INTO

在這里插入圖片描述

并沒有報錯,但是也沒有添加成功,忽略了重復數(shù)據(jù)的添加。

二、on duplicate key update

當主鍵或者唯一鍵重復時,則執(zhí)行update語句。

 ON DUPLICATE KEY UPDATE id = id

我們任然插入ID=1的員工記錄,并且修改一下其他字段(age=25):

在這里插入圖片描述

查看數(shù)據(jù)庫記錄:

在這里插入圖片描述

可以看到并沒有改變,數(shù)據(jù)也只有一條,并且返回了成功的提示。

這種方法有個前提條件,就是,需要插入的約束,需要是主鍵或者唯一約束(在你的業(yè)務中那個要作為唯一的判斷就將那個字段設置為唯一約束也就是unique key)。

擴展:這種方式還有其他業(yè)務場景的需求->>>定時更新其他字段。

我們在員工表中,再加入一個時間字段:

private Date updateTime;

在這里插入圖片描述

然后我們根據(jù)updateTime字段來插入數(shù)據(jù):

<insert id="saveEmp" parameterType="com.dt.springbootdemo.entity.Employee">
    INSERT INTO t_employee(id, name, age, salary, department_id,update_time)
    VALUES (#{id},#{name},#{age},#{salary},#{departmentId},now())
    ON DUPLICATE KEY UPDATE update_time = now()
</insert>

在這里插入圖片描述

在這里插入圖片描述

在這里插入圖片描述

如果插入的時候需要更新其他字段(比如age),該怎么做呢?

在這里插入圖片描述
在這里插入圖片描述

在這里插入圖片描述

三、replace into

如果存在primary or unique相同的記錄,則先刪除掉。再插入新記錄。

REPLACE INTO
 <!--插入員工數(shù)據(jù)-->
<insert id="saveEmp" parameterType="com.dt.springbootdemo.entity.Employee">
    REPLACE INTO t_employee(id, name, age, salary, department_id,update_time)
    VALUES (#{id},#{name},#{age},#{salary},#{departmentId},now())
</insert>

在這里插入圖片描述

在這里插入圖片描述

總結:實際開發(fā)中,用得最多的就是第二種方式,進行的批量加。

<!--插入員工數(shù)據(jù)-->
<insert id="saveEmp" parameterType="java.util.List">
    INSERT INTO t_employee(id, name, age, salary, department_id,update_time)
    VALUES
    <foreach collection="list" item="item" index="index" separator=",">
        (#{item.id},#{item.name},#{item.age},#{item.salary},#{item.departmentId},now())
    </foreach>
    ON DUPLICATE KEY UPDATE id = id
</insert>

控制器:

@PostMapping("save")
@ResponseBody
public CommonResult<Employee> save(@RequestBody List<Employee> employeeList){
    return employeeService.saveEmp(employeeList);
}

在這里插入圖片描述

如果存在相同的ID,則不會重復添加。

總結

實際工作中,使用最多的是方法二,根據(jù)不同的場景選擇不同的方式使用。

到此這篇關于MySql批量插入時如何不重復插入數(shù)據(jù)的文章就介紹到這了,更多相關MySql不重復插入內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • MySql 修改密碼后的錯誤快速解決方法

    MySql 修改密碼后的錯誤快速解決方法

    今天在MySql5.6操作時報錯:You must SET PASSWORD before executing this statement解決方法,需要的朋友可以參考下
    2016-11-11
  • MySQL表的重命名字段添加及字段屬性修改操作語法

    MySQL表的重命名字段添加及字段屬性修改操作語法

    這篇文章主要為大家介紹了MySQL表的重命名字段添加及字段屬性修改語法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-05-05
  • MySQL之表碎片化的問題解決

    MySQL之表碎片化的問題解決

    MySQL數(shù)據(jù)庫的碎片是由于頻繁的增刪改查操作導致的數(shù)據(jù)塊不連續(xù)或不規(guī)則分布,本文主要介紹了MySQL之表碎片化的問題解決,具有一定的參考價值,感興趣的可以了解一下
    2024-08-08
  • MySQL中存儲過程的詳細詳解

    MySQL中存儲過程的詳細詳解

    存儲過程就是一條或者多條SQL語句的集合,可以視為批文件,它可以定義批量插入的語句,也可以定義一個接收不同條件的SQL,下面這篇文章主要給大家介紹了關于MySQL中存儲過程的相關資料,需要的朋友可以參考下
    2022-06-06
  • mysql分區(qū)表的增刪改查的實現(xiàn)示例

    mysql分區(qū)表的增刪改查的實現(xiàn)示例

    增刪查改在數(shù)據(jù)庫中是很常見的操作,本文主要介紹了mysql分區(qū)表的增刪改查的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,需要的朋友們下面隨著小編來一起學習學習吧
    2024-01-01
  • 你的like語句為什么沒索引詳解

    你的like語句為什么沒索引詳解

    這篇文章主要給大家介紹了關于你的like語句為什么沒索引的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用mysql具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2018-10-10
  • 利用ssh tunnel鏈接mysql服務器的方法

    利用ssh tunnel鏈接mysql服務器的方法

    這篇文章主要給大家介紹了利用ssh tunnel鏈接mysql服務器的方法,文中介紹的很詳細,需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-02-02
  • MySQL字符編碼設置方法

    MySQL字符編碼設置方法

    這篇文章主要介紹了MySQL字符編碼設置方法的相關資料,需要的朋友可以參考下
    2016-05-05
  • MySQL中隱式轉換的踩坑記錄以及解決方法分享

    MySQL中隱式轉換的踩坑記錄以及解決方法分享

    這篇文章主要和大家分享一個MySQL隱式轉換時踩過的坑,差點把服務器整崩潰了,以及最后的解決辦法。文中的示例代碼講解詳細,感興趣的可以了解一下
    2022-11-11
  • mysql中group by與having合用注意事項分享

    mysql中group by與having合用注意事項分享

    在mysql中group by分組查詢我們經(jīng)常會用到,并且還同時會與having合用,下面我介紹group by用法與having合用注意事項,希望此教程對各位朋友有所幫助
    2013-10-10

最新評論