mysql批量新增数据_批量更新sql语句

mysql批量新增数据_批量更新sql语句背景业务中存在唯一索引,插入的批量数据中可能存在已有数据,此时可用一条sql快速完成,无需写业务判断。原始sql#其中stock_id,date为唯一所以insertintomart_kline(stock_id,red_red_rate,red_green_rate,date)values(‘stockId1′,0.5,1.0,’2021-12-19’), (‘stockId2′,0.51,1.2,’2021-12-20’), (‘stockId3’,0

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

背景

业务中存在唯一索引,插入的批量数据中可能存在已有数据,此时可用一条sql快速完成,无需写业务判断。

原始sql

# 其中stock_id, date为唯一所以
insert into mart_kline(stock_id, red_red_rate, red_green_rate, date)
values ('stockId1', 0.5, 1.0, '2021-12-19'),
		('stockId2', 0.51, 1.2, '2021-12-20'),
	  	('stockId3', 0.52, 1.3, '2021-12-21')
on duplicate key 
update red_red_rate=values(red_red_rate),
		 red_green_rate=values(red_green_rate)

mybatis写法

<insert id="serversInsertOrUpdate" useGeneratedKeys="true" keyProperty="id">
        insert into mart_kline(stock_id, red_red_rate, red_green_rate, date)
		values <foreach collection="servers" separator="," item="server">
            (
            #{server.stockId},#{server.red_red_rate},#{server.red_red_rate},#{server.date}
            )
        </foreach>
        on duplicate key 
        update red_red_rate=values(red_red_rate),
		 red_green_rate=values(red_green_rate)
    </insert>

python

sql_kline = 'insert into mart_kline(stock_id, day_line_5, day_line_10, day_line_20, day_offset_5, day_offset_10, ' \
            'day_offset_20, red_red_rate, red_green_rate, date)' \
            'values (%s, %s, %s, %s, %s, %s, %s, %s, %s, %s) ' \
            'on duplicate key update red_red_rate=values(red_red_rate), red_green_rate=values(red_green_rate)'
cur.executemany(sql_kline, kline)
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/188335.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 四旋翼飞行器图片(4轴飞行器飞行运动中有)

    1、未知区域地形的构建2、农业方面的应用:(1)运用图像识别技术检测果实数量;(2)检测作物是否发生病虫害,因为当作物出现病虫害时都会有相应的表现现状。具体见链接http://www.aiweibang.com/yuedu/153474153.html3、高层建筑物的搭建

    2022年4月15日
    47
  • oracle批量插入数据

    oracle批量插入数据

    2021年9月12日
    71
  • 深入理解Java虚拟机–javac命令[通俗易懂]

    深入理解Java虚拟机–javac命令[通俗易懂]目录指定编译源文件命令选项非标准选项-Xjavac命令用于将.java源文件编译成.class字节码文件,在windows命令行中使用”javac-help”命令查看其用法:语法格式:javac<options><sourcefiles>options#命令行选项,可指定多个…

    2022年5月28日
    40
  • bWAPP靶场实战[通俗易懂]

    bWAPP靶场实战[通俗易懂]文章目录一、靶场介绍二、靶场搭建2.1安装类型2.2独立安装三、漏洞实战SSRF远程文件包含端口扫描一、靶场介绍  集成了超过100余个网络漏洞,phpweb漏洞靶场,能够调制漏洞难度等级(低->中->高)。二、靶场搭建下载:https://sourceforge.net/projects/bwapp/2.1安装类型搭建类型有两种:(虚拟机版本可测试测漏洞类型更多,比如破壳、心脏滴血)独立安装(部署到apache+php+mysql环境下)虚拟机安装(bee

    2022年9月16日
    6
  • springboot+dynamicDataSource动态添加切换数据源

    springboot+dynamicDataSource动态添加切换数据源

    2020年11月9日
    310
  • DataX使用指南

    DataX使用指南简介DataX是阿里巴巴集团内被广泛使用的离线数据同步工具/平台,实现包括MySQL、Oracle、HDFS、Hive、OceanBase、HBase、OTS、ODPS等各种异构数据源之间高效的数据同步功能。DataX采用了框架+插件的模式,目前已开源,代码托管在github。DataX安装部署及小试1.下载压缩包:下载页面地址:https://github.com/a…

    2022年5月16日
    52

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号