前言:用mybatis也好几年了,mybatis在批量的增删操作也写起来也是比较简单的,只有批量更新这一块是特别坑,特此记录。

注:本文主要用来记录oracle和mysql数据库在使用mybatis的情况下批量增、删、改(更新)的常用写法

一、批量插入

1、oracle写法:

<insert id="insertZaixcsList" parameterType="cc.eguid.Zaixcs">

        insert into b_dbgl_zaixcs (

zaixcsid, mingc, pingsyid, xinxid, fujid, 

jieg, pingfjg, pingf, zhuangt, shic,

startriq, endriq, pingfriq, datr, pingfr, beiz

)

        <foreach collection="list" item="item" index="index" separator="union all">

            (select #{item.zaixcsid,jdbcType=VARCHAR}, #{item.mingc,jdbcType=VARCHAR},

#{item.pingsyid,jdbcType=VARCHAR},#{item.xinxid,jdbcType=VARCHAR}, 

#{item.fujid,jdbcType=VARCHAR}, #{item.jieg,jdbcType=VARCHAR},

#{item.pingfjg,jdbcType=VARCHAR}, #{item.pingf,jdbcType=DECIMAL},

#{item.zhuangt,jdbcType=VARCHAR},#{item.shic,jdbcType=DECIMAL}, 

#{item.startriq,jdbcType=TIMESTAMP}, #{item.endriq,jdbcType=TIMESTAMP},

#{item.pingfriq,jdbcType=TIMESTAMP}, #{item.datr,jdbcType=VARCHAR},

#{item.pingfr,jdbcType=VARCHAR},#{item.beiz,jdbcType=VARCHAR}

             from dual)

        </foreach>

    </insert>

2、mysql写法:

 insert into B_SYS_FUJ (FUJ_ID, RELATE_ID, RELATE_TABLE_NAME, FUJ_LX, WENJLX,WENJM, FJMC, FUJ_PATH,CREATE_USER_ID, CREATE_USER, CREATE_TIME, RELATE_TABLE_ZIDUAN,CONTENTTYPE,ZHUANGT)

values

 <foreach collection="list" item="item" index="index" separator="," >   

(#{item.fujId,jdbcType=VARCHAR}, 

 #{item.relateId,jdbcType=VARCHAR},

 #{item.relateTableName,jdbcType=VARCHAR},

 #{item.fujLx,jdbcType=VARCHAR}, 

 #{item.wenjlx,jdbcType=VARCHAR},

 #{item.wenjm,jdbcType=VARCHAR},

 #{item.fjmc,jdbcType=VARCHAR},

 #{item.fujPath,jdbcType=VARCHAR},

 #{item.createUserId,jdbcType=VARCHAR},

 #{item.createUser,jdbcType=VARCHAR},

 #{item.createTime,jdbcType=TIMESTAMP},

 #{item.relateTableZiduan,jdbcType=VARCHAR},

 #{item.contentType,jdbcType=VARCHAR},

 #{item.zhuangt,jdbcType=VARCHAR}

 )

 </foreach> 

二、批量删除

注:批量删除操作oracle与mysql写法相同
当collection=”array“时,表名参数为数组;
当collection=”list“时,表名参数为集合;

1、删除数组数组

<delete id="batchDeleteEmpArr" parameterType="int">

        delete from emp where empno in

        <foreach item="empnoItem" collection="array" open="(" separator="," close=")">

            #{empnoItem}

        </foreach>

    </delete>

2、删除list列表数据

<delete id="batchDeleteEmpList" parameterType="int">

        delete from emp where empno in

        <foreach item="item" collection="list" open="(" separator="," close=")">

            #{item}

        </foreach>

    </delete>

3、删除查询到的数据

<delete id="deleteByParent" parameterType="string">

delete from QIYDFBZ where BIAOZBID in(

SELECT biaozbid

FROM

B_DBGL_QIYDFBZ 

CONNECT BY PRIOR FENXID = FUJID start WITH BIAOZBID = #{biaozbid,jdbcType=VARCHAR} )

</delete>

三、批量更新

1、oracle写法:

注:这样的写法虽然可以更新,但是更新操作返回值是-1,并没有返回更新的行数
<update id="updateBatch" parameterType="com.itssky.aqjg.entity.dbgl.Zaixcs">

begin

 <foreach collection="list" item="item" index="index" separator=";">

update B_DBGL_ZAIXCS

<trim prefix="set" suffixOverrides=",">

<if test="item.mingc != null and item.mingc !=''">

MINGC= #{item.mingc,jdbcType=VARCHAR},

</if>

<if test="item.pingf != null and item.pingf !=''">

PINGF=#{item.pingf,jdbcType=DECIMAL},

</if>

<if test="item.zhuangt != null and item.zhuangt !=''">

ZHUANGT=#{item.zhuangt,jdbcType=VARCHAR},

</if>

<if test="item.shic != null and item.shic !=''">

SHIC=#{item.shic,jdbcType=DECIMAL},

</if>

<if test="item.startriq != null and item.startriq !=''">

STARTRIQ=#{item.startriq,jdbcType=TIMESTAMP},

</if>

</trim>

where ZAIXCSID = #{item.zaixcsid,jdbcType=VARCHAR}

</foreach>

;end;

</update>

2、mysql写法:

注:mysql数据库连接需要加上&allowMultiQueries=true

例如:jdbc:mysql://192.168.1.236:3306/test?useUnicode=true&amp;characterEncoding=UTF-8&allowMultiQueries=true


<update id="batchUpdate"  parameterType="java.util.List">

<foreach collection="list" item="item" index="index" open="" close="" separator=";">

update ZAIXCS

<trim prefix="set" suffixOverrides=",">

<if test="item.mingc != null and item.mingc !=''">

MINGC= #{item.mingc,jdbcType=VARCHAR},

</if>

<if test="item.shic != null and item.shic !=''">

SHIC=#{item.shic,jdbcType=DECIMAL},

</if>

<if test="item.startriq != null and item.startriq !=''">

STARTRIQ=#{item.startriq,jdbcType=TIMESTAMP},

</if>

<if test="item.beiz != null and item.beiz !=''">

BEIZ=#{item.beiz,jdbcType=VARCHAR},

</if>

</trim>

where ZAIXCSID = #{item.zaixcsid,jdbcType=VARCHAR}

</foreach>
 

    </update>







mybatis批量增、删、改(更新)操作oracle和mysql批量写法小记的更多相关文章

  1. 怎样从C#中打开数据库并进行 增 删 改 查 操作

    首先 在C#中引用数据库的操作! (因为我们用的是SQLserver数据库,所以是SqlClient) using System.Data.SqlClient; 1:要实现对数据库的操作,我们必须先登 ...

  2. MVC EF 增 删 改 查

    using System;using System.Collections.Generic;using System.Linq;using System.Web;//using System.Data ...

  3. 好用的SQL TVP~~独家赠送[增-删-改-查]的例子

    以前总是追求新东西,发现基础才是最重要的,今年主要的目标是精通SQL查询和SQL性能优化.  本系列主要是针对T-SQL的总结. [T-SQL基础]01.单表查询-几道sql查询题 [T-SQL基础] ...

  4. 第18课-数据库开发及ado.net 连接数据库.增.删.改向表中插入数据并且返回自动编号.SQLDataReade读取数据

    第18课-数据库开发及ado.net 连接数据库.增.删.改向表中插入数据并且返回自动编号.SQLDataReade读取数据 ADO.NET 为什么要学习? 我们要搭建一个平台(Web/Winform ...

  5. C# ADO.NET (sql语句连接方式)(增,删,改)

    using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.We ...

  6. iOS sqlite3 的基本使用(增 删 改 查)

    iOS sqlite3 的基本使用(增 删 改 查) 这篇博客不会讲述太多sql语言,目的重在实现sqlite3的一些基本操作. 例:增 删 改 查 如果想了解更多的sql语言可以利用强大的互联网. ...

  7. ADO.NET 增 删 改 查

    ADO.NET:(数据访问技术)就是将C#和MSSQL连接起来的一个纽带 可以通过ADO.NET将内存中的临时数据写入到数据库中 也可以将数据库中的数据提取到内存中供程序调用 ADO.NET所有数据访 ...

  8. django ajax增 删 改 查

    具于django ajax实现增 删 改 查功能 代码示例: 代码: urls.py from django.conf.urls import url from django.contrib impo ...

  9. StringBuilder修改字符串内容,增,删,改,插

    package seday01;/** * 字符串不变对象特性只针对字符串重用,并没有考虑修改操作的性能.因此String不适合频繁修改内容. * 若有频繁修改操作,使用StringBuilder来完 ...

随机推荐

  1. Cf #353 D. Tree Construction

    题目链接:http://codeforces.com/problemset/problem/675/D 题目大意是将一个没有相同数字的数列中的数字依次插入到二叉搜索树中,问除了第一个数字以外,其他数字 ...

  2. PMBOK 学习与实践分享视频

    本系列为自己在学习PMBOK时进行的总结与分享,每一节主要包括两部分: 对PMBOK本身的一个结构笔记和讲解. 对自己项目管理工作的一个总结和思考. PMBOK 学习与实践分享视频内容清单 人力资源管 ...

  3. 京东商城首页jquery轮播特效

    <!DOCTYPE html><html> <head> <meta charset="utf-8" /> <title> ...

  4. placeholder各种浏览器兼容问题

    只要在页面上引入placeholder.min文件,再以$('input,textarea').placeholder(); 就可以兼容ie等各种浏览器. placeholder.min.js文件链接 ...

  5. Laravel 5.2 教程 - 迁移

    一.简介 迁移(Migrations)是一种数据库的版本控制.可以让团队在修改数据库结构的同时,保持彼此的进度一致.迁移通常会和 结构生成器 一起使用,可以简单的管理数据库结构. 下面以创建学生表的迁 ...

  6. 『算法』Dinic求最大流

    作为一个[NOIP+,省选-]算法,这个算法真的很暴力.同样是最大流,跑得比EK不知快到哪里去了.首先是一个 广度优先搜索() { 按照可用路径上节点的访问顺序标号. 然后判断一下能否到汇点. 如果不 ...

  7. 利刃 MVVMLight 9:Messenger

    MVVM的目标之一就是为了解耦View和ViewModel.View负责视图展示,ViewModel负责业务逻辑处理,尽量保证 View.xaml.cs中的简洁,不包含复杂的业务逻辑代码. 但是在实际 ...

  8. Day3 Pyhon的六大数据类型

    Python3 中有六个标准的数据类型: Number(数字) String(字符串) List(列表) Tuple(元组) Sets(集合) Dictionary(字典) Number(数字) Py ...

  9. 使用java API操作hdfs--拷贝部分文件到hdfs

    要求如下: 自行在本地文件系统生成一个大约一百多字节的文本文件,写一段程序(可以利用Java API或C API),读入这个文件,并将其第101-120字节的内容写入HDFS成为一个新文件. impo ...

  10. 搭建后台页面布局利用属性target 属性

    HTML 5 <form> target 属性 HTML 5 <form> 标签 实例 提交一个在新窗口中打开的表单: <form action="demo_f ...