Mybatis批量更新详解
转:http://www.cnblogs.com/winkey4986/p/3915151.html
Mybatis批量更新
批量操作就不进行赘述了。减少服务器与数据库之间的交互。网上有很多关于批量插入还有批量删除的帖子。但是批量更新却没有详细的解决方案。
实现目标
这里主要讲的是1张table中。根据不同的id值,来update不同的property。
数据表:1张。Tblsupertitleresult。错题结果统计。
表结构:
表中每一条数据必须通过两个字段来确定:userHhCode+titleId
需要批量更新的字段是:correctDate,result,checkState。
1批量更新的sql语句
我用的数据库是mysql。其他数据库的sql语句也都大同小异。
用mybatis的mapper-xml进行组装sql之前需要写出批量操作的sql语句。
Sql:
update tblsupertitleresult set result =case
when (userHhCode=2001 and titleId=1)then 90
when (userHhCode=2001 and titleId=2)then 70
end
,checkState = case
when (userHhCode=2001 and titleId=1)then 80
when (userHhCode=2001 andtitleId=2)then 120
end
where (userHhCode=2001 and titleId=1) or(userHhCode=2001 and titleId=2)
关于这个批量更新的sql语句做一个简单的解释。
要更新userHhCode=2001,titleId=1和userHhCode=2001 ,titleId=2的两条数据。
当userHhCode=2001,titleId=1时,将result设置为90,checkState设置为80
当userHhCode=2001,titleId=2时,将result设置为80,checkState设置为120.
这是mysql语句。运行没有问题。接下来就是mybatis的mapper-xml
Mybatis中mapper-xml
这里,首先介绍实体类。

public classWrongTitle { //manipulatetable of tblsupertitleresult private String titleId; private String titleIdNew; private String result; private String checkState; private String isCollect; private String times; private String wrongDate; private String wrongNum; private String collectDate; private String userHhCode; private String correctDate; private String tid;// teacher who will review this wrong title private String paperTitleId;

getter和set方法省略。
好了现在开始介绍mybatis里面的几个标签。由于一些原因,mybatis的技术文档和用户指南所介绍得并不详细。
<foreach>标签:foreach元素的属性主要有item,index,collection,open,separator,close。item表示集合中每一个元素进行迭代时的别名,
index指定一个名字,用于表示在迭代过程中,每次迭代到的位置,
open表示该语句以什么开始,
separator表示在每次进行迭代之间以什么符号作为分隔符,
close表示以什么结束,
在使用foreach的时候最关键的也是最容易出错的就是collection属性,该属性是必须指定的,但是在不同情况下,该属性的值是不一样的,主要有一下3种情况:
1.如果传入的是单参数且参数类型是一个List的时候,collection属性值为list;
2.如果传入的是单参数且参数类型是一个array数组的时候,collection的属性值为array;
3.如果传入的参数是多个的时候,我们就需要把它们封装成一个Map了,当然单参数也可以封装成map,实际上如果你在传入参数的时候,在MyBatis里面也是会把它封装成一个Map的,map的key就是参数名,所以这个时候collection属性值就是传入的List或array对象在自己封装的map里面的key;
关于以上三种collection的用法。百度上有很多帖子。这里不进行赘述。
<trim>标签:有四个属性:
Prefix: 指的是<trim></trim>所包含的部分(body)以什么开头。
prefixOverrides:指<trim>中如果有内容时可忽略(body)前的匹配字符。
suffix: 指的是<trim></trim>所包含的部分(body)以什么结尾。
suffixOverrides:指<trim>中如果有内容时可忽略(body)后的匹配字符。
接下来直接上:
Mapper-xml

<update id="batchUpdate"> update tblsupertitleresult <trim prefix="set" suffixOverrides=","> <trim prefix="checkState =case" suffix="end,"> <foreach collection="list"item="i" index="index"> <if test="i.checkState!=null"> when (userHhCode=#{i.userHhCode} and titleId=#{i.titleId}) then #{i.checkState} </if> </foreach> </trim> <trim prefix=" correctDate =case" suffix="end,"> <foreach collection="list"item="i" index="index"> <if test="i.correctDate!=null"> when (userHhCode=#{i.userHhCode} and titleId=#{i.titleId}) then #{i.correctDate} </if> </foreach> </trim> <trim prefix="result =case" suffix="end," > <foreach collection="list"item="i" index="index"> <if test="i.result!=null"> when (userHhCode=#{i.userHhCode} and titleId=#{i.titleId}) then #{i.result} </if> </foreach> </trim> </trim> where <foreach collection="list" separator="or" item="i" index="index"> (userHhCode =#{i.userHhCode} andtitleId=#{i.titleId}) </foreach> </update>

接下来就是dao:
public interface DatacenterDAO{
// batch update super title_result_view
public intbatchUpdate(List<WrongTitle> list );
Test类
public classTestBatch {
/**
* @param args
*/
public static voidmain(String[] args) {
ApplicationContext context = newClassPathXmlApplicationContext("applicationContext.xml");
DatacenterDAO dao = context.getBean(DatacenterDAO.class);
ArrayList<WrongTitle> list = newArrayList<WrongTitle>();
WrongTitle t1=new WrongTitle();
WrongTitle t2=new WrongTitle();
WrongTitle t3=new WrongTitle();
WrongTitle t4=new WrongTitle();
t1.setTitleId(3+"");
t2.setTitleId(4+"");
t3.setTitleId(5+"");
t4.setTitleId(6+"");
t1.setUserHhCode(2001+"");
t2.setUserHhCode(2001+"");
t3.setUserHhCode(2001+"");
t4.setUserHhCode(2001+"");
t1.setCheckState(5+"");
t2.setCheckState(6+"");
t3.setCheckState(7+"");
t4.setCheckState(8+"");
t1.setResult(10+"");
t2.setResult(12+"");
t3.setResult(14+"");
t4.setResult(16+"");
list.add(t1);
list.add(t2);
list.add(t3);
list.add(t4);
int i=dao.batchUpdate(list);
System.out.println("操作了"+i+"行数据");
}
运行结果截图:
希望能帮助到大家~。~
================
亲测可用,但是不知道效率到底如何。
Mybatis批量更新详解的更多相关文章
- MyBatis Mapper XML 详解
MyBatis Mapper XML 详解 MyBatis 真正的力量是在映射语句中.这里是奇迹发生的地方.对于所有的力量,SQL 映射的 XML 文件是相当的简单.当然如果你将它们和对等功能的 JD ...
- 深入浅出mybatis之启动详解
深入浅出mybatis之启动详解 MyBatis功能丰富,但使用起来非常简单明了,今天我们来追踪一下它的启动过程. 目录 如何启动MyBatis 如何使用MyBatis MyBatis启动过程 如何启 ...
- Mybatis案例超详解(上)
Mybatis案例超详解(上) 前言: 本来是想像之前一样继续跟新Mybatis,但由于种种原因,迟迟没有更新,快开学了,学了一个暑假,博客也更新了不少,我觉得我得缓缓,先整合一些案例练练,等我再成熟 ...
- mybatis代码生成器配置文件详解
mybatis代码生成器配置文件详解 更多详见 http://generator.sturgeon.mopaas.com/index.html http://generator.sturgeon.mo ...
- mybatis批量更新报错badsql
mybatis批量更新时语法写的都对,但是报错,需要在连接上面加上allowMultiQueries=true 示例:jdbc:MySQL://192.168.1.236:3306/test?useU ...
- mybatis批量更新update-设置多个字段值 报错 You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near
mybatis批量更新update-设置多个字段值 2016年08月01日 12:49:26 姚一号 阅读数:29539 标签: mysql mybatis批量更新批量更新allowMultiQuer ...
- MyBatis核心配置文件详解
------------------------siwuxie095 MyBatis 核心配置文件详解 1.核心 ...
- Mybatis批量更新<转>
Mybatis批量更新 批量操作就不进行赘述了.减少服务器与数据库之间的交互.网上有很多关于批量插入还有批量删除的帖子.但是批量更新却没有详细的解决方案. 实现目标 这里主要讲的是1张table中.根 ...
- 《深入理解mybatis原理2》 Mybatis初始化机制详解
<深入理解mybatis原理> Mybatis初始化机制详解 对于任何框架而言,在使用前都要进行一系列的初始化,MyBatis也不例外.本章将通过以下几点详细介绍MyBatis的初始化过程 ...
随机推荐
- 【WXS全局对象】consloe
consloe对象 方法: 原型:console.log( [String] ) 说明:用于在 console 窗口输出信息,一般用于程序调试使用示例: console.log支持arguments类 ...
- 人艰不拆之破解低版本IE不兼容mediaQuery
先放个链接 大家预览下 http://scottjehl.github.io/Respond/test/test.html 值得注意的是 将页面源代码下载到本地时,直接用IE打开是没有效果的.需要把静 ...
- 剑指offer-顺时针打印矩阵19
题目描述 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下4 X 4矩阵: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 则依次打印出数 ...
- Python3 标准库:calendar,time
1.calendar import calendar print(calendar.month(2008,8)) #某个月 print(calendar.calendar(2008)) #某年 pri ...
- 《剑指Offer》题三十一~题四十
三十一.栈的压入.弹出序列 题目:输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否为该栈的弹出顺序.假设压入栈的数字均不相等.例如,序列{1, 2, 3, 4 ,5}是某栈的压栈序列 ...
- TensorFlow源码框架 杂记
一.为什么我们需要使用线程池技术(ThreadPool) 线程:采用“即时创建,即时销毁”策略,即接受请求后,创建一个新的线程,执行任务,完毕后,线程退出: 线程池:应用软件启动后,立即创建一定数量的 ...
- "亿家App"问卷调查分析结果及心得体会
一.问卷问题设计 调查背景:随着现代社会互联网的发展,基于家庭产生的服务项目也越来越多.为增加家庭之间的交流和互助,增加家庭内部.家庭与家庭之间的沟通互助,并利用互联网便捷交流的优势,使家庭在享受服务 ...
- django 安装/部署过程
一.软件安装 1.升级linux中的python 参考“centos升级python” 2.安装apache(httpd) 3.安装django,先要安装setuptools 参考“安装dj ...
- 简单名称值对节点类NameValuePair
本类位于System.Data.dll中,名为:System.Data.Common.NameValuePair.主要用途是在DBConnectionString类中,解析ConnectionStri ...
- Python2中编码错误---éç»äººè¡¨ç®çé¿å ååè¶(æå格式转化为UTF-8
在python2的使用中,总会遇到各种各样的编码问题,这也是使用Python2最头疼的一件事情,幸好python3解决了编码的问题. 下面我在爬虫时遇到的类似éç»äººè¡¨ç®çé¿ ...