程序笔记   发布时间:2022-07-04  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了MySQL + PostgreSQL批量插入更新insertOrUpdate大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

5; 周周有福利࿰c;周周有惊喜 哪吒社区 - 风火轮计划 ἴ5; Java学习路线配套文章:Java学习路线总结࿰c;搬砖工逆袭Java架构师(全网最强) ἴ5; Java经典面试题大全:10万字208道Java经典面试题总结(附答案) ἴ5; 简介:Java领域优质创作者🏆、CSDN哪吒公众号作者ɰc; 、Java架构师奋斗者💪 ἴ5; 扫描主页左侧二维码࿰c;加入群聊࿰c;一起学习、一起进步 ἴ5; 欢迎点赞 👍 收藏 ⭐留言 📝 ἴ5; 粉丝福利 文末有送书活动

目录

    • 一、百度百科
      • 1、MySQL
      • 2、POSTGReSQL
      • 3、POSTGReSQL相对于MySQL的优势
    • 二、POSTGRes中insertOrupdate代码实例
      • 1、创建user表
      • 2、简单的方式实现
      • 3、利用unnest函数实现
      • 4、如果数据已存在࿰c;就就什么也不做
    • 三、相关重点函数简介
      • 1、unnest(anyarray)
    • 四、userMapper.xml写法
    • 五、MySQL中insertOrupdate代码实例
    • 六、《MySQL技术大全:开发、优化与运维实战》图书推荐
      • 【内容简介】
    • 七、粉丝福利
      • 获取方式
      • 【赚取积分方式】哪吒社区内发帖、点赞、评论都可赢取积分!

一、百度百科

1、MySQL

@H_86_6@mySQL声称自己是最流行的开源数据库。LAMP中的M指的就是MySQL。构建在LAMP上的应用都会使用MySQL࿰c;如WordPress、Drupal等大多数php开源程序。MySQL最初是由MySQL AB开发的࿰c;然后在2008年以10亿美金的价格卖给了Sun公司࿰c;Sun公司又在2010年被Oracle收购。Oracle支持MySQL的多个版本:Standard、Enterprise、Classic、Cluster、Embedded与Community。其中有一些是免费下载的࿰c;另外一些则是收费的。其核心代码基于GPL许可࿰c;由于MySQL被控制在Oracle࿰c;社区担心会对MySQL的开源会有影响࿰c;所以开发了一些分支࿰c;比如: MariaDB和Percona。

2、POSTGReSQL

POSTGReSQL标榜自己是世界上最先进的开源数据库。POSTGReSQL的一些粉丝说它能与Oracle相媲美࿰c;而且没有那么昂贵的价格和傲慢的客服。最初是1985年在加利福尼亚大学伯克利分校开发的࿰c;作为Ingres数据库的后继。POSTGReSQL是完全由社区驱动的开源项目。它提供了单个完整功能的版本࿰c;不像mysql那样提供了多个不同的社区版、商业版与企业版。POSTGReSQL基于自由的BSD/MIT许可࿰c;组织可以使用、复制、修改和重新分发代码࿰c;只需要提供一个版权声明即可。

3、POSTGReSQL相对于MySQL的优势

(1)不仅仅是关系型数据库࿰c;还可以存储:

array࿰c;不管是一位数组还是多为数组均支持 json(hStorE)和jsonb࿰c;相比使用text存储接送要高效很多 (2)支持地理信息处理扩展

(3)可以快速构建REST API

(4)支持R-trees这样可扩展的索引类型࿰c;可以更方便地处理一些特殊数据。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、如果数据已存在࿰c;就就什么也不做

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 nothing

三、相关重点函数简介

1、unnest(anyarray)

unnest函数将输入的数组转换成一个表࿰c;这个表的每一列都代表相应的一个数组中的元素。 如果unnest与其他字段一起出现在SELEct中࿰c;就相当于其他字段进行了一次join。

主要用于完成行转列的场景。

SELEct '张三' as name, unnest(Array['语文','数学','英语']) as course;
 name | course
------+--------
 张三 | 语文
 张三 | 数学
 张三 | 英语
(3 rows)

INSERT ON CONFLICT实现POSTGReSQL插入更新特性。

EXCLUDED虚拟表࿰c;其包含我们要更新的记录

四、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" >
<@H_608_126@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>
</@H_608_126@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` datetiR_497_11845@e(0) NULL DEFAULT NULL,
  `update_time` datetiR_497_11845@e(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表示插入更新数据࿰c;当记录中有primaryKeyc;或者unique索引的话࿰c;如果数据库已经存在数据࿰c;则用新数据更新(update)࿰c;如果没有数据效果则和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表示插入替换数据࿰c;当记录中有primaryKeyc;或者unique索引的话࿰c;如果数据库已经存在数据࿰c;则用新数据替换(先delete再insert)࿰c;如果没有数据效果则和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表示尽可能的忽略冲突࿰c;暴力插入。

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批量插入时c;都满足事务的原子性与一致性࿰c;但要注意insert into SELEct的加锁问题。 replacE into与insert into on duplicate key update都可以实现批量的插入更新࿰c;具体是更新还是插入取决与记录中的pk或uk数据在表中是否存在。如果存在࿰c;前者是先delete后insert࿰c;后者是update。 insert ignorE into会忽略很多数据上的冲突与约束࿰c;平时很少使用。

六、《MySQL技术大全:开发、优化与运维实战》图书推荐

【内容简介】

《MySQL技术大全:开发、优化与运维实战(视频教学版)》结合大量示例和实战案例࿰c;全面、系统、深入地介绍了MySQL数据库技术࿰c;重点阐述了MySQL开发、优化和运维过程中的各个技术点。《MySQL技术大全:开发、优化与运维实战(视频教学版)》对学习MySQL技术有较高的参价值࿰c;尤其是环境搭建、优化、维护和架构等内容可直接用于实际工作中。

《MySQL技术大全:开发、优化与运维实战(视频教学版)》共33章࿰c;分为6篇。第1篇“MySQL基础”࿰c;介绍数据库的定义、发展࿰c;以及数据库技术和MySQL数据库的三大范式与存储引擎。第2篇“环境搭建”࿰c;介绍vmware虚拟机以及Windows、Mac OS X和CentOS操作系统的安装࿰c;并介绍如何在三大操作系统上安装和配置MySQL。第3篇“MySQL开发”࿰c;介绍MySQL中的数据库操作、数据表操作、数据类型、运算符、函数、数据变更、数据查询、索引、视图、存储过程、触发器、分区、公用表表达式和生成列等。第4篇“MySQL优化”࿰c;介绍MySQL中的查询优化、索引优化、sql语句优化、数据库优化、服务器优化、应用程序优化及其他优化技术。第5篇“MySQL运维”࿰c;介绍MySQL中各种命令行工具的使用࿰c;以及各种日志的开启、查看、删除与关闭࿰c;并介绍数据的备份与恢复及MySQL中的账户管理。第6篇“MySQL架构”࿰c;介绍MySQL中的复制、读写分离环境搭建࿰c;以及如何实现R_497_11845@ySQL的高可用架构等。

MySQL + PostgreSQL批量插入更新insertOrUpdate

当当网链接:MySQL技术大全:开发、优化与运维实战

七、粉丝福利

送书啦࿰c;大家期待已久的价值199元的《MySQL技术大全:开发、优化与运维实战》

本次活动送书规则:

获取方式

四个选项需全部满足࿰c;限量五本࿰c;先到先得。

  1. 拉10人进微信交流群(仅限程序员)
  2. 新进群的小伙伴需关注哪吒公众号
  3. 新进群的小伙伴一键三连Java学习路线总结࿰c;搬砖工逆袭Java架构师(全网最强)
  4. 哪吒社区积分榜前二十

【赚取积分方式】哪吒社区内发帖、点赞、评论都可赢取积分!

5; 社区入口:哪吒社区入口

5; 周周有福利࿰c;周周有惊喜:哪吒社区 - 风火轮计划

MySQL + PostgreSQL批量插入更新insertOrUpdate

添加微信࿰c;加入风火轮计划࿰c;赠送Java学习路线思维导图

扫码加入技术交流群!

MySQL + PostgreSQL批量插入更新insertOrUpdate


扫码关注微信公众号࿰c;回复1024࿰c;获取Java学习思维导图

 

MySQL + PostgreSQL批量插入更新insertOrUpdate

MySQL + PostgreSQL批量插入更新insertOrUpdate

大佬总结

以上是大佬教程为你收集整理的MySQL + PostgreSQL批量插入更新insertOrUpdate全部内容,希望文章能够帮你解决MySQL + PostgreSQL批量插入更新insertOrUpdate所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。