mybatis动态数据更新 + 批量动态数据插入
动态更新 <update id="updateElevator" parameterType="com.diantijiang.saas.data.elevator.Elevator" >
update dc_elevator
<set>
<if test="inspectionCode != null">inspection_code = #{inspectionCode,jdbcType=VARCHAR},</if>
<if test="brandCode!=null">brand_code = #{brandCode},</if>
<if test="modelSpecs!=null">model_specs = #{modelSpecs},</if>
<if test="elevatorType!=null">elevator_type=#{elevatorType},</if>
<if test="idDistrict!=null">id_district=#{idDistrict},</if>
<if test="idPropertyCompany!=null">id_property_company=#{idPropertyCompany},</if>
<if test="idServiceCompany!=null">id_service_company=#{idServiceCompany},</if>
<if test="idServiceManager!=null">id_service_manager=#{idServiceManager},</if>
<if test="contractCode!=null">contract_code=#{contractCode},</if>
<if test="runStatus!=null">run_status=#{runStatus},</if>
<if test="qrCodeCheck!=null">qr_code_check=#{qrCodeCheck},</if>
<if test="qrCodeProduct!=null">qr_code_product=#{qrCodeProduct},</if>
<if test="lastAnnualDate!=null">last_annual_date=#{lastAnnualDate},</if>
<if test="nextAnnualDate!=null">next_annual_date=#{nextAnnualDate},</if>
<if test="lastMaintainDate!=null">last_maintain_date=#{lastMaintainDate},</if>
<if test="nextMaintainDate!=null">next_maintain_date=#{nextMaintainDate},</if>
<if test="repairTimes!=null">repair_times=#{repairTimes},</if>
<if test="maintainTimes!=null">maintain_times=#{maintainTimes},</if>
<if test="accessoriesExchanges!=null">accessories_exchanges=#{accessoriesExchanges},</if>
<if test="installDate!=null">Install_date=#{installDate},</if>
<if test="status!=null">status=#{status},</if>
<if test="createdBy!=null">created_by=#{createdBy},</if>
<if test="createdDate!=null">created_date=#{createdDate},</if>
<if test="updatedBy!=null">updated_by=#{updatedBy},</if>
<if test="updatedDate!=null">updated_date=#{updatedDate}</if>
</set>
where
id_elevator = #{idElevator}
</update> 批量动态插入
<insert id="batchInsert" parameterType="java.util.List" >
insert into dc_elevator
(
<foreach collection="list" separator="," item="item" index="index">
<if test="item.inspectionCode != null">inspection_code,</if>
<if test="item.brandCode!=null">brand_code,</if>
<if test="item.modelSpecs!=null">model_specs,</if>
<if test="item.elevatorType!=null">elevator_type,</if>
<if test="item.idDistrict!=null">id_district,</if>
<if test="item.idPropertyCompany!=null">id_property_company,</if>
<if test="item.idServiceCompany!=null">id_service_company,</if>
<if test="item.idServiceManager!=null">id_service_manager,</if>
<if test="item.contractCode!=null">contract_code,</if>
<if test="item.runStatus!=null">run_status,</if>
<if test="item.qrCodeCheck!=null">qr_code_check,</if>
<if test="item.qrCodeProduct!=null">qr_code_product,</if>
<if test="item.lastAnnualDate!=null">last_annual_date,</if>
<if test="item.nextAnnualDate!=null">next_annual_date,</if>
<if test="item.lastMaintainDate!=null">last_maintain_date,</if>
<if test="item.nextMaintainDate!=null">next_maintain_date,</if>
<if test="item.repairTimes!=null">repair_times,</if>
<if test="item.maintainTimes!=null">maintain_times,</if>
<if test="item.accessoriesExchanges!=null">accessories_exchanges,</if>
<if test="item.installDate!=null">Install_date,</if>
<if test="item.status!=null">status,</if>
<if test="item.createdBy!=null">created_by,</if>
<if test="item.createdDate!=null">created_date,</if>
<if test="item.updatedBy!=null">updated_by,</if>
<if test="item.updatedDate!=null">updated_date,</if>
id_elevator
</foreach>
)
values
<foreach collection="list" index="index" item="item" separator=",">
(
<if test="item.inspectionCode != null">#{item.inspectionCode},</if>
<if test="item.brandCode!=null">#{item.brandCode},</if>
<if test="item.modelSpecs!=null">#{item.modelSpecs},</if>
<if test="item.elevatorType!=null">#{item.elevatorType},</if>
<if test="item.idDistrict!=null">#{item.idDistrict},</if>
<if test="item.idPropertyCompany!=null">#{item.idPropertyCompany},</if>
<if test="item.idServiceCompany!=null">#{item.idServiceCompany},</if>
<if test="item.idServiceManager!=null">#{item.idServiceManager},</if>
<if test="item.contractCode!=null">#{item.contractCode},</if>
<if test="item.runStatus!=null">#{item.runStatus},</if>
<if test="item.qrCodeCheck!=null">#{item.qrCodeCheck},</if>
<if test="item.qrCodeProduct!=null">#{item.qrCodeProduct},</if>
<if test="item.lastAnnualDate!=null">#{item.lastAnnualDate},</if>
<if test="item.nextAnnualDate!=null">#{item.nextAnnualDate},</if>
<if test="item.lastMaintainDate!=null">#{item.lastMaintainDate},</if>
<if test="item.nextMaintainDate!=null">#{item.nextMaintainDate},</if>
<if test="item.repairTimes!=null">#{item.repairTimes},</if>
<if test="item.maintainTimes!=null">#{item.maintainTimes},</if>
<if test="item.accessoriesExchanges!=null"> #{item.accessoriesExchanges},</if>
<if test="item.installDate!=null">#{item.installDate},</if>
<if test="item.status!=null">#{item.status},</if>
<if test="item.createdBy!=null">#{item.createdBy},</if>
<if test="item.createdDate!=null">#{item.createdDate},</if>
<if test="item.updatedBy!=null">#{item.updatedBy},</if>
<if test="item.updatedDate!=null">#{item.updatedDate},</if>
#{item.idElevator}
)
</foreach>
</insert> 动态插入,返回主键
<insert id="insertCardWithId" parameterType="com.diantijiang.saas.account.entity.BankCard">
/*先插入,再将主键返回实体*/
<selectKey resultType="java.lang.Long" order="AFTER" keyProperty="cardId">
SELECT LAST_INSERT_ID()
</selectKey>
/*插入*/
INSERT INTO ac_bank_card
<trim prefix="(" suffix=")" suffixOverrides=",">
bank_name,
card_number,
<if test="null != expiryDate and ''!= expiryDate">expiry_date,</if>
ower,
account_id
</trim>
VALUES
<trim prefix="(" suffix=")" suffixOverrides=",">
#{bankName},
#{cardNumber},
<if test="null != expiryDate and ''!=expiryDate">
#{expiryDate},
</if>
#{ower},
#{accountId}
</trim>
</insert>
mybatis动态数据更新 + 批量动态数据插入的更多相关文章
- sql 根据指定条件获取一个字段批量获取数据插入另外一张表字段中+MD5加密
/****** Object: StoredProcedure [dbo].[getSplitValue] Script Date: 03/13/2014 13:58:12 ******/ SET A ...
- .NET批量大数据插入性能分析及比较
数据插入使用了以下几种方式 1. 逐条数据插入2. 拼接sql语句批量插入3. 拼接sql语句并使用Transaction4. 拼接sql语句并使用SqlTransaction5. 使用DataAda ...
- C#批量将数据插入SQLServer数据库
Database db = CreateDatabase(); var varConnnection = db.CreateConnection(); //获取连 ...
- Jquery 动态生成表单 并将表单数据 批量通过Ajax插入到数据库
利用Jquery 动态生成 Table 表单 之后利用each 方法来遍历所有文本框获取文本的value值 并通过Ajax 将数据 提交到Web服务里把数据插入数据库 Html页面 <!DOC ...
- hive从查询中获取数据插入到表或动态分区
Hive的insert语句能够从查询语句中获取数据,并同时将数据Load到目标表中.现在假定有一个已有数据的表staged_employees(雇员信息全量表),所属国家cnty和所属州st是该表的两 ...
- mybatis使用序列批量插入数据
mybatis只提供了单条数据的插入,要批量插入数据我们可以使用循环一条条的插入,但是这样做的效率太低下,每插入一条数据就需要提交一次,如果数据量几百上千甚至更多,插入性能往往不是我们能接受的,如下例 ...
- MyBatis Plus 批量数据插入功能,yyds!
最近 Review 小伙伴代码的时候,发现了一个小小的问题,小伙伴竟然在 for 循环中进行了 insert (插入)数据库的操作,这就会导致每次循环时都会进行连接.插入.断开连接的操作,从而导致一定 ...
- MyBatis 使用 foreach 批量插入
MyBatis 使用 foreach 批量插入 参考博文 老司机学习MyBatis之动态SQL使用foreach在MySQL中批量插入 使用MyBatis一次性插入多条数据时候可以使用 <for ...
- Mybatis映射原理,动态SQL,log4j
1.理清mybatis中的#和$之间的区别? #{ }:表示一个预处理参数,参数类型不定,是根据传入的参数类型来设定的. 类似于JDBC中的? 特例使用,模糊查询:(针对oracle): and us ...
随机推荐
- Java三种方式实现栈和队列
栈:LIFO(后进先出) 队列:FIFO(先进先出) 1.栈:LIFO(后进先出) 1.1.栈的顺序存储结构实现: /** * 基于数组实现的顺序栈 * @param <E> */ pub ...
- 49个Spring经典面试题总结,附带答案,赶紧收藏
1. 一般问题 1.1. 不同版本的 Spring Framework 有哪些主要功能? Version Feature Spring 2.5 发布于 2007 年.这是第一个支持注解的版本. Spr ...
- Eureka源码探索(一)-客户端服务端的启动和负载均衡
1. Eureka源码探索(一)-客户端服务端的启动和负载均衡 1.1. 服务端 1.1.1. 找起始点 目前唯一知道的,就是启动Eureka服务需要添加注解@EnableEurekaServer,但 ...
- 爬虫框架之Scrapy(一)
scrapy简介 scrapy是一个用python实现为了爬取网站数据,提取结构性数据而编写的应用框架,功能非常的强大. scrapy常应用在包括数据挖掘,信息处理或者储存历史数据的一系列程序中. s ...
- @vue/cli 3.0 使用 svg-sprite-loader 加载本地 SVG 文件
目录 @vue/cli 3.0 使用 svg-sprite-loader 加载本地 SVG 文件 运行 使用 配置 svg-sprite-loader 调用当前环境下的颜色 props @vue/cl ...
- Redis缓存你必须了解的!
不管你是从事Python.Java.Go.PHP.Ruby等等… Redis都应该是一个比较熟悉的中间件.而大部分经常写业务代码的程序员,实际工作中或许只用到了set value.get value两 ...
- 用消息队列和socket实现聊天系统
前言:最近在学进程间通信,所以做了一个小项目练习一下.主要用消息队列和socket(UDP)实现这个系统,并数据库存储数据,对C语言操作不熟悉的可以参照我的这篇博客:https://www.cnblo ...
- 谈谈axios配置请求头content-type
现在前端开发中需要通过Ajax发送请求获取后端数据是很普遍的一件事情了,鉴于我平时在撸码中用的是vue技术栈,今天这里来谈谈我们常用的发Ajax请求的一个插件-axios. > 现在网上可能发送 ...
- Python爬虫实例:爬取猫眼电影——破解字体反爬
字体反爬 字体反爬也就是自定义字体反爬,通过调用自定义的字体文件来渲染网页中的文字,而网页中的文字不再是文字,而是相应的字体编码,通过复制或者简单的采集是无法采集到编码后的文字内容的. 现在貌似不少网 ...
- python学习第四讲,python基础语法之判断语句,循环语句
目录 python学习第四讲,python基础语法之判断语句,选择语句,循环语句 一丶判断语句 if 1.if 语法 2. if else 语法 3. if 进阶 if elif else 二丶运算符 ...