个人博客网:https://wushaopei.github.io/    (你想要这里多有)

批量增删改的接口:

public interface BookService {

        //批量增加	

	int saveList(List<Book> records);
//批量查找 List<Book> selectList(List<Integer> ids); //批量删除
int deleteList(List<Integer> ids); //批量修改
int updateList(List<Book> bookList); }

接口实现类:

@Service
public class BookServiceImpl implements BookService{ @Autowired
BookMapper bookMapper; @Override
public int saveList(List<Book> list) {
// TODO Auto-generated method stub
int count = bookMapper.inserts(list);
return count;
} @Override
public List<Book> selectList(List<Integer> ids) {
// TODO Auto-generated method stub List<Book> books = bookMapper.selectByIds(ids);
return books;
} @Override
public int deleteList(List<Integer> ids) {
// TODO Auto-generated method stub
return bookMapper.deleteByPrimaryKeys(ids);
} @Override
public int updateList(List<Book> bookList) {
// TODO Auto-generated method stub return bookMapper.updateByPrimaryKeys(bookList);
} }

对应的实体类 JavaBean :

public class Book {
public Book(Integer id, String name, String author, BigDecimal price, Integer sales, Integer stock) {
super();
this.id = id;
this.name = name;
this.author = author;
this.price = price;
this.sales = sales;
this.stock = stock;
}
............省略

mapper.xml 中SQL 语句的编写:

  <!-- 批量根据id进行删除 -->
<delete id="deleteByPrimaryKeys" parameterType="java.util.List" >
delete from t_book
where id in
<foreach collection="list" item="id" open="(" close=")" separator="," >
#{id,jdbcType=INTEGER}
</foreach>
</delete> <!-- 批量进行插入数据 --> <insert id="inserts" parameterType="java.util.List"> insert into t_book (id,name,author,price,sales,stock) values <foreach collection="list" item="Book" separator="," index="index"> (null, #{Book.name}, #{Book.author}, #{Book.price}, #{Book.sales}, #{Book.stock}) </foreach> </insert> <!-- 批量根据id进行修改 --> <update id="updateByPrimaryKeys" parameterType="java.util.List" >
update t_book
<trim prefix="set" suffixOverrides=",">
<trim prefix="name=case" suffix="end,">
<foreach collection="list" item="Book" index="index">
<if test="Book.name!=null">
when id=#{Book.id} then #{Book.name}
</if>
</foreach>
</trim>
<trim prefix="name=case" suffix="end,">
<foreach collection="list" item="Book" index="index">
<if test="Book.author!=null">
when id=#{Book.id} then #{Book.author}
</if>
</foreach>
</trim>
<trim prefix="name=case" suffix="end,">
<foreach collection="list" item="Book" index="index">
<if test="Book.price!=null">
when id=#{Book.id} then #{Book.price}
</if>
</foreach>
</trim>
<trim prefix="name=case" suffix="end,">
<foreach collection="list" item="Book" index="index">
<if test="Book.sales!=null">
when id=#{Book.id} then #{Book.sales}
</if>
</foreach>
</trim>
<trim prefix="name=case" suffix="end,">
<foreach collection="list" item="Book" index="index">
<if test="Book.stock!=null">
when id=#{Book.id} then #{Book.stock}
</if>
</foreach>
</trim>
</trim>
where
<foreach collection="list" separator="or" item="Book" index="index">
id=#{Book.id,jdbcType=INTEGER}
</foreach>
</update> <!-- 批量根据id查找 --> <select id="selectByIds" resultMap="BaseResultMap" parameterType="java.lang.Integer" >
select id, name, author, price, sales, stock
from t_book
where id in
<foreach collection="list" item="id" open="(" close=")" separator="," >
#{id,jdbcType=INTEGER}
</foreach> </select>

测试: test 对批量操作进行测试是否成功:

/*
* 批量插入
* */
@Test
public void InsertBookServices()throws SQLException { List<Book> bookList = new ArrayList<>();
bookList.add(new Book(null,"生活1","奕1君",new BigDecimal(1),1,1));
bookList.add(new Book(null,"生活2","奕2君",new BigDecimal(2),2,2));
bookList.add(new Book(null,"生活3","奕3君",new BigDecimal(3),3,3));
bookList.add(new Book(null,"生活4","奕4君",new BigDecimal(4),4,4));
bookList.add(new Book(null,"生活5","奕5君",new BigDecimal(5),5,5)); int count = bookService.saveList(bookList);
System.out.println(count);
} /*
* 批量查询
* */
@Test
public void SelectBookService()throws SQLException { List<Integer> Ids = new ArrayList();
Ids.add(1);
Ids.add(2);
Ids.add(3);
Ids.add(4); List<Book> Books = bookService.selectList(Ids); for(Book book : Books) {
System.out.println(book.toString());
}
} /*
* 批量删除
* */
@Test
public void DeleteBookService()throws SQLException { List<Integer> Ids = new ArrayList();
Ids.add(1);
Ids.add(2);
Ids.add(3);
Ids.add(4); int counts = bookService.deleteList(Ids);
System.out.println(counts); } /*
* 批量更新
* */
@Test
public void UpdateBookService()throws SQLException { List<Book> bookList = new ArrayList<>();
bookList.add(new Book(6,"生活6","奕6君",new BigDecimal(1),1,1));
// bookList.add(new Book(7,"生活7","奕7君",new BigDecimal(2),2,2));
bookList.add(new Book(8,"生活8","奕8君",new BigDecimal(3),3,3));
bookList.add(new Book(9,"生活9","奕9君",new BigDecimal(4),4,4));
bookList.add(new Book(10,"生活10","奕10君",new BigDecimal(5),5,5)); int count = bookService.updateList(bookList);
System.out.println(count); }

链接:https://pan.baidu.com/s/1oAYg5X8eeqf18dUTU1bUpA
提取码:jznv
复制这段内容后打开百度网盘手机App,操作更方便哦

Mybatis 的动态SQL,批量增删查改的更多相关文章

  1. ASP.NET动态的网页增删查改

    动态页面的增删查改,不多说了,直接上代码 跟前面的一般处理程序一样我上用的同一套三层,只是UI层的东西不一样,在纠结着要不要重新在上一次以前上过的代码: 纠结来纠结去,最后我觉得还上上吧,毕竟不上为我 ...

  2. MERGE批量增删查改数据

    MERGE优点: 在批量处理数据的时候,我可以用到merge一次完成数据处理. 示例代码一: MERGE INTO student AS t using ( AS age) s ON t.Age=s. ...

  3. dbflow 批量 增删查改

    @ModelContainer @Table(database = DemoDatabase.class) class Person extends BaseModel implements Seri ...

  4. 通过web sql实现增删查改

    <!DOCTYPE html><html><head lang="en"> <meta charset="UTF-8" ...

  5. Mybatis基础配置及增删查改操作

    一.简介 平时我们都用JDBC访问数据库,除了需要自己写SQL之外,还必须操作Connection, Statement, ResultSet 这些其实只是手段的辅助类. 不仅如此,访问不同的表,还会 ...

  6. mybatis实现简单的增删查改

    接触一个新技术,首先去了解它的一些基本概念,这项技术用在什么方面的.这样学习起来,方向性也会更强一些.我对于mybatis的理解是,它是一个封装了JDBC的java框架.所能实现的功能是对数据库进行增 ...

  7. 常用SQL语句(增删查改、合并统计、模糊搜索)

    转自:http://www.cnblogs.com/ljianhui/archive/2012/08/13/2695906.html 常用SQL语句 首行当然是最基本的增删查改啦,其中最重要的是查. ...

  8. Sql Server的艺术(一) 视图的增删查改

    视图是从一个或者多个表中查询数据的另一种方式.利用视图可以集中.简化定制数据库,同时还能保障安全. 视图其结构和数据是建立在对应的查询基础上的.和表一样,视图也是包括几个被定义的数据列和多个数据行,但 ...

  9. SQL Server 表的管理_关于数据增删查改的操作的详解(案例代码)

    SQL Server 表的管理_关于数据增删查改的操作的详解(案例代码)-DML 1.SQL INSERT INTO 语句(在表中插入) INSERT INTO 语句用于向表中插入新记录. SQL I ...

随机推荐

  1. 王颖奇 201771010129《面向对象程序设计(java)》第六周学习总结

    实验六 继承定义与使用 实验时间 2018-9-28 1.目的与要求 理论部分: 继承(inheritance): 继承的特点:具有结构层次:子类继承了父类的域和方法. 主要内容: (1)类.子类.超 ...

  2. 【漫画】JAVA并发编程之并发模拟工具

    原创声明:本文来源于公众号[胖滚猪学编程],转载请注明出处. 上一节[漫画]JAVA并发编程三大Bug源头(可见性.原子性.有序性)我们聊了聊并发编程的三个bug源头,这还没开始进入并发世界,胖滚猪就 ...

  3. javascript操作字符串间隔显示随机颜色

    参考了另一篇文章 https://www.cnblogs.com/zjfree/p/11584177.html,原理在这篇文章已经有详细描述了. 然后结合自己的一些js基础,当然改成jquery也可以 ...

  4. Python --表达式和运算符

    表达式 由一个或者几个数字或者变量和运算符组合成的一行代码 通常会返回一个结果 运算符 由一个以上的值经过变化得到新值的过程就叫做运算 用于运算的符号称为运算符 运算符的分类: 算数运算符 比较或者关 ...

  5. extract变量覆盖

    0x01 extract变量覆盖 <?php $flag='xxx'; extract($_GET); if(isset($shiyan)) { $content=trim(file_get_c ...

  6. 黑马程序员_毕向东_Java基础视频教程——类型转换(随笔)

    类型转换 class Test{ public static void main(String[] args) { byte b = 3; // b = b + 2; /* Test.java:5: ...

  7. spring cloud系列教程第四篇-Eureka基础知识

    通过前三篇文章学习,我们搭建好了两个微服务工程.即:order80和payment8001这两个服务.有了这两个基础的框架之后,我们将要开始往里面添加东西了.还记得分布式架构的几个维度吗?我们要通过一 ...

  8. eclipse 整合mybatis的过程

    一.下载mybatis和数据库驱动的jar,我这里用到的数据库是pgAdmin III ,所以我下载的jar包分别为mybatis-3.0.2 jar和po's'tgresql-42.2.1.jar, ...

  9. ES6常见面试题

    1.es5和es6的区别,说一下你所知道的es6 ECMAScript5,即ES5,是ECMAScript的第五次修订,于2009年完成标准化 ECMAScript6,即ES6,是ECMAScript ...

  10. xtrabackup手册笔记

    http://www.cnblogs.com/Amaranthus/archive/2014/08/19/3922570.html#_Toc396231219