Mybatis 的动态SQL,批量增删查改
个人博客网: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,批量增删查改的更多相关文章
- ASP.NET动态的网页增删查改
动态页面的增删查改,不多说了,直接上代码 跟前面的一般处理程序一样我上用的同一套三层,只是UI层的东西不一样,在纠结着要不要重新在上一次以前上过的代码: 纠结来纠结去,最后我觉得还上上吧,毕竟不上为我 ...
- MERGE批量增删查改数据
MERGE优点: 在批量处理数据的时候,我可以用到merge一次完成数据处理. 示例代码一: MERGE INTO student AS t using ( AS age) s ON t.Age=s. ...
- dbflow 批量 增删查改
@ModelContainer @Table(database = DemoDatabase.class) class Person extends BaseModel implements Seri ...
- 通过web sql实现增删查改
<!DOCTYPE html><html><head lang="en"> <meta charset="UTF-8" ...
- Mybatis基础配置及增删查改操作
一.简介 平时我们都用JDBC访问数据库,除了需要自己写SQL之外,还必须操作Connection, Statement, ResultSet 这些其实只是手段的辅助类. 不仅如此,访问不同的表,还会 ...
- mybatis实现简单的增删查改
接触一个新技术,首先去了解它的一些基本概念,这项技术用在什么方面的.这样学习起来,方向性也会更强一些.我对于mybatis的理解是,它是一个封装了JDBC的java框架.所能实现的功能是对数据库进行增 ...
- 常用SQL语句(增删查改、合并统计、模糊搜索)
转自:http://www.cnblogs.com/ljianhui/archive/2012/08/13/2695906.html 常用SQL语句 首行当然是最基本的增删查改啦,其中最重要的是查. ...
- Sql Server的艺术(一) 视图的增删查改
视图是从一个或者多个表中查询数据的另一种方式.利用视图可以集中.简化定制数据库,同时还能保障安全. 视图其结构和数据是建立在对应的查询基础上的.和表一样,视图也是包括几个被定义的数据列和多个数据行,但 ...
- SQL Server 表的管理_关于数据增删查改的操作的详解(案例代码)
SQL Server 表的管理_关于数据增删查改的操作的详解(案例代码)-DML 1.SQL INSERT INTO 语句(在表中插入) INSERT INTO 语句用于向表中插入新记录. SQL I ...
随机推荐
- node常用插件使用
1.nodemon 用于热更新,随时监控文件的变化 安装npm i -g nodemon 使用nodemon index.js 2.nvm nvm用于nodejs版本管理,我们在开发过程中,不同的项目 ...
- Java实现栈(链表和线性表两种方法实现)
一.栈的介绍 任何数据结构都是一种规则 栈就是在最基础的结构--线性结构和链式结构上面定义规则形成的 如果对基本数据结构(线性表和链表)有疑问的同学可以看我之前的博客:https://www.cnbl ...
- 记录一下关于在工具类中更新UI使用RunOnUiThread犯的极其愚蠢的错误
由于Android中不能在子线程中更新ui,所以平时在子线程中需要更新ui时可以使用Android提供的RunOnUiThread接口,但是最近在写联网工具类的时候,有时候会出现联网异常,这个时候为了 ...
- Qt之xml文件解析
XML文件简介 XML - EXtensible Markup Language,可拓展标记语言 Qt中加载XML模块 .pro 文件中添加 QT += xml Qt的XML访问方式 引用:https ...
- train loss与test loss结果分析/loss不下降
train loss与test loss结果分析 train loss 不断下降,test loss不断下降,说明网络仍在学习; train loss 不断下降,test loss趋于不变,说明网络过 ...
- 【Hadoop离线基础总结】网站流量日志数据分析系统
目录 点击流数据模型 概述 点击流模型 网站流量分析 网站流量模型分析 网站流量来源 网站流量多维度细分 网站内容及导航分析 网站转化及漏斗分析 流量常见分析角度和指标分类 指标概述 指标分类 分析角 ...
- 真正免费,不限页数的PDF转Word工具
真正免费,不限页数的PDF转Word工具 我们知道PDF转Word工具非常多,但大部分都有各种限制,限大小,限页数,加水印等等. 这其中绝大部分其实并不能做到格式完全一样,遇到图片更是直接傻了. 我们 ...
- 【漫画】读写锁ReadWriteLock还是不够快?再试试StampedLock!
本文来源于公众号[胖滚猪学编程] 转载请注明出处! 在互斥锁ReentrantLock不好用?试试读写锁ReadWriteLock一文中,我们对比了互斥锁ReentrantLock和读写锁ReadWr ...
- js 正则(部分)
/** * 增加大于某个值的验证 */window.ParsleyValidator.addValidator( 'greater', function (value,greater) { if(is ...
- 12个让您震撼的Linux终端命令
以下快捷键很有用,可以节省你的时间: CTRL+U: 从光标处删除文本直到行首. CTRL+K: 从光标处删除文本直到行尾. CTRL+Y: 粘贴文本. CTRL+E: 将光标移动到行尾. CTRL+ ...