婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 實操MySQL+PostgreSQL批量插入更新insertOrUpdate

實操MySQL+PostgreSQL批量插入更新insertOrUpdate

熱門標簽:高清地圖標注道路 大眾點評星級酒店地圖標注 400電話可以辦理嗎 云南電商智能外呼系統價格 智能外呼系統復位 臨清電話機器人 話務外呼系統怎么樣 外東北地圖標注 拉卡拉外呼系統

一、百度百科

1、MySQL

MySQL聲稱自己是最流行的開源數據庫。LAMP中的M指的就是MySQL。構建在LAMP上的應用都會使用MySQL,如WordPress、Drupal等大多數php開源程序。

MySQL最初是由MySQL AB開發的,然后在2008年以10億美金的價格賣給了Sun公司,Sun公司又在2010年被Oracle收購。Oracle支持MySQL的多個版本:Standard、Enterprise、Classic、Cluster、Embedded與Community。其中有一些是免費下載的,另外一些則是收費的。

其核心代碼基于GPL許可,由于MySQL被控制在Oracle,社區擔心會對MySQL的開源會有影響,所以開發了一些分支,比如: MariaDB和Percona。

2、PostgreSQL

PostgreSQL標榜自己是世界上最先進的開源數據庫。

PostgreSQL的一些粉絲說它能與Oracle相媲美,而且沒有那么昂貴的價格和傲慢的客服。

最初是1985年在加利福尼亞大學伯克利分校開發的,作為Ingres數據庫的后繼。PostgreSQL是完全由社區驅動的開源項目。

它提供了單個完整功能的版本,而不像MySQL那樣提供了多個不同的社區版、商業版與企業版。

PostgreSQL基于自由的BSD/MIT許可,組織可以使用、復制、修改和重新分發代碼,只需要提供一個版權聲明即可。

3、PostgreSQL相對于MySQL的優勢

(1)不僅僅是關系型數據庫,還可以存儲:

array,不管是一位數組還是多為數組均支持json(hStore)和jsonb,相比使用text存儲接送要高效很多

(2)支持地理信息處理擴展

(3)可以快速構建REST API

(4)支持R-trees這樣可擴展的索引類型,可以更方便地處理一些特殊數據。MySQL 處理樹狀的設計會很復雜, 而且需要寫很多代碼, 而 PostgreSQL 可以高效處理樹結構。

(5)更好的外部數據源支持

(6)字符串沒有長度限制

等等...

二、postgres中insertOrUpdate代碼實例

1、創建user表

CREATE TABLE public.t_user (
    username varchar(100) NOT NULL,
    age int4 NOT NULL DEFAULT 0,
    "password" varchar(100) NULL,
    deleted int4 NULL,
    created_time timestamp NULL
);
CREATE UNIQUE INDEX t_user_union_name_age_password ON public.t_user USING btree (username, password, age);

2、簡單的方式實現

insert
    into
    public.t_user (username , password,age,created_time)
values ('zs', '123', 18,now()), ('ls', '123456', 19,now()),('ww', '123', 20,now()) 
on conflict (username, age,password) do update set username = excluded.username,age = excluded.age,password = excluded.password,created_time = excluded.created_time

3、利用unnest函數實現

insert
    into
    public.t_user (username , password,age,created_time)
values (unnest(array['zs', 'ls', 'ww']), unnest(array['123', '123', '123456']),unnest(array[18, 19, 20]), unnest(array[now(), now(), now()])) 
on conflict (username, age,password) do update set username = excluded.username,age = excluded.age,password = excluded.password,created_time = excluded.created_time

4、如果數據已存在,就就什么也不做

三、相關重點函數簡介

1、unnest(anyarray)

unnest函數將輸入的數組轉換成一個表,這個表的每一列都代表相應的一個數組中的元素。
如果unnest與其他字段一起出現在select中,就相當于其他字段進行了一次join。

主要用于完成行轉列的場景。

INSERT ON CONFLICT實現PostgreSQL插入更新特性。

EXCLUDED虛擬表,其包含我們要更新的記錄

四、userMapper.xml寫法

?xml version="1.0" encoding="UTF-8" ?>
!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
mapper namespace="com.guor.dao.UserMapper">
 
    !-- 批量插入 -->
    insert id="batchInsert" parameterType="java.util.HashMap">
         include refid="batchInsertSql">/include>
    /insert>
 
    sql id="batchInsertSql">
        INSERT INTO ${map.tableInfo.schemaName}.${map.tableInfo.tableName}
        (
        "table_id",
        "file_name",
        "create_time",
        foreach collection="map.list.get(0)" index="key" item="value"
                 separator=",">
            "${key}"
        /foreach>
        )
        VALUES
        foreach collection="map.list" item="list" separator=",">
            (
            ${map.tableInfo.tableId},
            #{map.tableInfo.fileName},
            now(),
            foreach collection="list" index="key" item="value"
                     separator=",">
                choose>
                    when test="map.varcharList.contains(key)">
                        #{value}
                    /when>
                    when test="map.dateList.contains(key)">
                        TO_TIMESTAMP(#{value},'yyyy-MM-dd hh24:mi:ss')
                    /when>
                    otherwise>
                        ${value}
                    /otherwise>
                /choose>
            /foreach>
            )
        /foreach>
    /sql>
 
    !-- 批量插入更新 -->
    insert id="batchInsertOrUpdate" parameterType="java.util.HashMap">
        include refid="batchInsertSql">/include>
        on conflict (
        file_name, table_id
        if test="map.tableInfo.flag">
            , "id_number"
        /if>
        ) do update
        set
        "table_id" = excluded."table_id",
        "file_name" = excluded."file_name",
        "create_time" = excluded."create_time",
        foreach collection="map.list.get(0)" index="key" separator=",">
            "${key}" = excluded."${key}"
        /foreach>
    /insert>
/mapper>

五、MySQL中insertOrUpdate代碼實例

1、建表語句

CREATE TABLE `t_user`  (
  `username` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
  `password` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
  `age` int(0) NULL DEFAULT NULL,
  `address` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
  `create_time` datetime(0) NULL DEFAULT NULL,
  `update_time` datetime(0) NULL DEFAULT NULL,
  `version` int(0) NOT NULL,
  UNIQUE INDEX `user_union_index`(`username`, `password`, `age`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;

2、普通方式

INSERT INTO t_user
(username,password,age,create_time) 
VALUES('張三' ,'123456',18,NOW())
ON DUPLICATE KEY UPDATE 
username='張三',
password='123456',
create_time=now()

3、ON DUPLICATE KEY UPDATE

insert into on duplicate key update表示插入更新數據,當記錄中有PrimaryKey,或者unique索引的話,如果數據庫已經存在數據,則用新數據更新(update),如果沒有數據效果則和insert into一樣。

INSERT INTO t_user 
(username,password,age,create_time,update_time,version)
VALUES( 'zs' ,'123',10,now(),now(),1) 
,( 'ls' ,'123456',20,now(),now(),1) 
,( 'ww' ,'123',30,now(),now(),1) 
ON DUPLICATE KEY UPDATE 
username= VALUES(username)
,password=VALUES(password)
,age=VALUES(age)
,update_time=VALUES(update_time)
,version = version + 1

4、REPLACE INTO

replace into表示插入替換數據,當記錄中有PrimaryKey,或者unique索引的話,如果數據庫已經存在數據,則用新數據替換(先delete再insert),如果沒有數據效果則和insert into一樣。

REPLACE INTO t_user 
(username,password,age,create_time,update_time,version) 
VALUES 
( 'zs' ,'123',10,now(),now(),1) 

5、INSERT IGNORE INTO

insert ignore into表示盡可能的忽略沖突,暴力插入。

INSERT IGNORE INTO t_user 
(username,password,age,create_time,update_time,version) 
VALUES 
( 'zs' ,'123',10,now(),now(),1) ,
( '哪吒' ,'123',30,now(),now(),2) 

6、小結

insert into values 或 insert into select批量插入時,都滿足事務的原子性與一致性,但要注意insert into select的加鎖問題。
replace into與insert into on duplicate key update都可以實現批量的插入更新,具體是更新還是插入取決與記錄中的pk或uk數據在表中是否存在。

如果存在,前者是先delete后insert,后者是update。
insert ignore into會忽略很多數據上的沖突與約束,平時很少使用。

到此這篇關于如何實現MySQL + PostgreSQL批量插入更新insertOrUpdate的文章就介紹到這了,更多相關MySQL + PostgreSQL批量插入更新insertOrUpdate內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • MySQL update set 和 and的區別
  • MySQL UPDATE 語句的非標準實現代碼
  • mysql update case 更新字段值不固定的操作
  • Mysql update多表聯合更新的方法小結
  • mysql事務select for update及數據的一致性處理講解
  • MySQL UPDATE 語句一個“經典”的坑

標簽:三明 定西 山西 福州 無錫 溫州 阿里 揚州

巨人網絡通訊聲明:本文標題《實操MySQL+PostgreSQL批量插入更新insertOrUpdate》,本文關鍵詞  實操,MySQL+PostgreSQL,批量,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《實操MySQL+PostgreSQL批量插入更新insertOrUpdate》相關的同類信息!
  • 本頁收集關于實操MySQL+PostgreSQL批量插入更新insertOrUpdate的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产美女在线观看一区| 一卡二卡三卡日韩欧美| 日韩精品一区二区三区中文精品 | 色噜噜狠狠成人中文综合| 国产福利一区在线观看| 国产最新精品免费| 成人性生交大片免费看视频在线 | 日本亚洲三级在线| 日韩精品成人一区二区在线| 日韩激情在线观看| 男女男精品视频| 国产一区不卡在线| 大胆亚洲人体视频| av一区二区久久| 在线观看91视频| 欧美精品在线一区二区三区| 欧美精品一级二级| 精品99一区二区| 中文字幕一区二区三区四区不卡 | 日本午夜精品一区二区三区电影| 日韩电影在线免费观看| 国产自产视频一区二区三区| 国产91对白在线观看九色| www.日韩大片| 欧美日韩精品一区二区三区 | 99re亚洲国产精品| 欧美最猛性xxxxx直播| 欧美一区二区三区影视| 久久久亚洲午夜电影| 一区二区三区四区不卡在线| 午夜国产精品一区| 国产美女视频一区| 91国偷自产一区二区三区成为亚洲经典| 在线精品视频免费观看| 欧美疯狂做受xxxx富婆| 国产精品污www在线观看| 亚洲一区在线观看视频| 麻豆精品蜜桃视频网站| 成人免费视频视频| 日韩视频免费观看高清在线视频| 欧美激情中文不卡| 日韩高清在线不卡| 91浏览器打开| 精品国产123| 亚洲一级不卡视频| 成人国产精品视频| 日韩一区二区电影| 亚洲欧美日韩国产综合在线| 爽爽淫人综合网网站| 99久久综合国产精品| 欧美日韩国产一二三| 国产精品久久夜| 久久er精品视频| 欧美自拍偷拍午夜视频| 欧美国产禁国产网站cc| 青青国产91久久久久久| 91黄色激情网站| 中文幕一区二区三区久久蜜桃| 日韩成人精品在线观看| 色老汉一区二区三区| 国产午夜亚洲精品理论片色戒| 午夜不卡在线视频| av激情成人网| 国产欧美日韩综合精品一区二区| 看电视剧不卡顿的网站| 欧美二区乱c少妇| 亚洲成av人影院| 欧美日韩国产经典色站一区二区三区| 国产精品久久毛片a| 国产福利一区二区三区| 欧美—级在线免费片| 国产福利不卡视频| 中文字幕高清一区| 成人午夜私人影院| 欧美激情在线一区二区| 成人天堂资源www在线| 久久综合九色综合97_久久久| 免费成人性网站| 欧美一区二区观看视频| 五月天丁香久久| 欧美伦理视频网站| 日韩av一区二| 日韩欧美国产三级| 国模一区二区三区白浆| 日本一区二区三区高清不卡| 福利一区二区在线| 亚洲欧洲国产日本综合| 欧美性色综合网| 一区二区三区在线免费播放| 91国产福利在线| 污片在线观看一区二区| 欧美va亚洲va香蕉在线| 国产乱码字幕精品高清av| 国产目拍亚洲精品99久久精品| 成人免费观看av| 亚洲乱码中文字幕| 欧美日韩精品系列| 国产在线国偷精品产拍免费yy| 国产亚洲污的网站| 91色.com| 久久精品99国产精品| 国产精品美日韩| 欧美精品自拍偷拍| 黄色精品一二区| 综合色中文字幕| 欧美精品国产精品| 国产精品91一区二区| 亚洲黄色小说网站| 日韩欧美不卡在线观看视频| 激情成人综合网| 亚洲午夜视频在线观看| 久久亚洲免费视频| 在线免费观看日韩欧美| 国内精品国产三级国产a久久| 亚洲欧洲日本在线| 欧美va亚洲va在线观看蝴蝶网| 91原创在线视频| 国产真实乱对白精彩久久| 亚洲精品成人a在线观看| 精品sm在线观看| 欧美性生活久久| 国产福利91精品一区二区三区| 亚洲一区二区三区三| 久久综合色8888| 欧美一区二区三区电影| 一本色道久久综合亚洲aⅴ蜜桃| 极品少妇一区二区| 天天免费综合色| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆 | 亚洲第一成人在线| 国产网红主播福利一区二区| 欧美性高清videossexo| 91丨九色丨国产丨porny| 国产一级精品在线| 精品一区二区三区视频在线观看| 亚洲精品视频免费看| 国产精品国产三级国产专播品爱网| 日韩一级片在线播放| 欧美视频在线一区二区三区| 白白色 亚洲乱淫| 国产69精品久久777的优势| 久久草av在线| 久久99热这里只有精品| 日韩电影免费在线看| 天堂午夜影视日韩欧美一区二区| 亚洲人xxxx| 亚洲精品欧美专区| 亚洲精品菠萝久久久久久久| 亚洲色图视频网| 亚洲色图在线看| 一区二区三区在线高清| 一二三区精品视频| 视频精品一区二区| 美脚の诱脚舐め脚责91 | 中文字幕日韩av资源站| 久久精品人人爽人人爽| 久久久久久久久97黄色工厂| 久久久www成人免费毛片麻豆| 久久久美女艺术照精彩视频福利播放| 欧美一区二区日韩一区二区| 欧美一区二区成人| 精品国产一区二区在线观看| 欧美精品一区男女天堂| 日本一区二区免费在线| 亚洲欧洲成人自拍| 亚洲成人免费电影| 日韩成人一区二区| 精品一区二区三区影院在线午夜| 国产黄人亚洲片| 91网页版在线| 7777精品伊人久久久大香线蕉| 日韩写真欧美这视频| 精品国产凹凸成av人网站| 国产精品视频在线看| 亚洲国产aⅴ天堂久久| 捆绑紧缚一区二区三区视频| 国产成人免费网站| 日本韩国欧美三级| 日韩精品专区在线| 国产精品久久久久婷婷| 亚洲午夜久久久| 久国产精品韩国三级视频| 成人的网站免费观看| 欧美日韩亚洲不卡| 久久婷婷色综合| 亚洲午夜电影网| 国内精品伊人久久久久影院对白| 9i在线看片成人免费| 日韩一级在线观看| 国产精品欧美一区喷水| 日韩电影在线观看一区| 成人av高清在线| 日韩免费电影网站| **欧美大码日韩| 久久99国产精品麻豆| 色94色欧美sute亚洲线路二| 久久久久国产一区二区三区四区| 亚洲激情在线播放| 国产成人av一区二区| 欧美一区二区免费观在线|