mybatis批量删除Batch delete(1)

2、Mybatis批量删除注意事项:

1、 Mybatis删除这里主要考虑两种参数类型:数组或者集合.

而这点区别主要体现在UserDaoMapper.xml文件中标签的collection属性 :

当collection=”array “时,表名参数为数组;

当collection=”list “时,表名参数为集合.

2、UserDaoMapper.xml 配置

无论Mybatis是与mysql数据库结合,还是与Oracle数据库,都同样适合如下设置与操作.

delete from t_user where id

#{id}

二、Mybatis批量删除具体实现案例

======================================================================================

1、题目:

从queryAll.jsp页面中批量删除id为7,8,9的重复用户“周恒君”。

2、项目结构图

3、提前准备jar包

4、提前准备Mybatis工具类

package com.tjcu.util;

import org.apache.ibatis.io.Resources;

import org.apache.ibatis.session.SqlSession;

import org.apache.ibatis.session.SqlSessionFactory;

import org.apache.ibatis.session.SqlSessionFactoryBuilder;

import java.io.IOException;

import java.io.InputStream;

/**

  • @author 王恒杰

  • @version 1.0

  • @date 2021/10/12 9:52

  • @email 1078993387@qq.com

  • @Address 天津

  • @Description:

*/

public class MybatisUtil {

/**

  • 线程绑定对象,保证是同一个对象

*/

private static final ThreadLocal t1 = new ThreadLocal<>();

private static SqlSessionFactory factory;

static {

InputStream is = null;

try {

is = Resources.getResourceAsStream(“mybatis-config.xml”);

} catch (IOException e) {

e.printStackTrace();

}

factory = new SqlSessionFactoryBuilder().build(is);

}

/**

  • 创建SqlSession

  • @return sqlSession

*/

private static SqlSession openSession() {

SqlSession sqlSession = t1.get();

if (sqlSession == null) {

sqlSession = factory.openSession();

t1.set(sqlSession);

}

return sqlSession;

}

/**

  • 调用功能方法

  • @param clazz

  • @return Object

*/

public static Object getMapper(Class clazz) {

return openSession().getMapper(clazz);

}

/**

  • 关闭资源

*/

public static void close() {

if (openSession() != null) {

openSession().close();

}

t1.remove();

}

/**

  • 提交事务,关闭资源

*/

public static void commit() {

//1、提交事务

openSession().commit();

//2、关闭资源

close();

t1.remove();

}

/**

  • 回滚事务,关闭资源

*/

public static void rollback() {

//1、提交事务

openSession().rollback();

//2、关闭资源

close();

t1.remove();

}

}

5、实体类User

public class User {

private Integer id;

private String username;

private String password;

private int age;

private Date birthday;

6、UserDao接口:

public interface UserDao {

/**

  • 查询所有

  • @return用户集合

*/

public List selectUserAll();

/**

  • 根据id进行批量删除

  • @param ids

*/

public void BatchDelete(List ids);

}

7、UserDaoMapper.xml实现

select *

from t_user;

delete from t_user where id

#{id}

8、UserService接口

public interface UserService {

/**

  • 查询所有

  • @return

*/

public List queryAll();

/**

  • 批量删除

  • @param ids

*/

public void BatchDelete(List ids);

}

9、UserServiceImpl实现

public class UserServiceImpl implements UserService{

@Override

public List queryAll() {

//调用DAO

UserDao mapper = (UserDao) MybatisUtil.getMapper(UserDao.class);

List users = mapper.selectUserAll();

MybatisUtil.close();

return users;

}

@Override

public void BatchDelete(List ids) {

//调用DAO

UserDao mapper = null;

mapper = (UserDao) MybatisUtil.getMapper(UserDao.class);

mapper.BatchDelete(ids);

MybatisUtil.commit();

}

}

10、Struts2的Action类

public class UserAction extends ActionSupport {

//接收数据

/**

  • 替换request作用域传递数据

*/

private List users;

private List ids;

public String selectAll() throws Exception {

//调用业务

UserServiceImpl userService = new UserServiceImpl();

users = userService.queryAll();

System.out.println(users);

//跳转页面

return Action.SUCCESS;

}

public String BatchDelete(){

UserServiceImpl userService = new UserServiceImpl();

userService.BatchDelete(ids);

return “batachDeleteOK”;

}

public List getUsers() {

return users;

}

public void setUsers(List users) {

this.users = users;

}

public List getIds() {

return ids;

}

public void setIds(List ids) {

this.ids = ids;

}

}

11、Struts2的Web.xml过滤配置【WEB-IF下】

struts

org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter

struts

/*

12、Struts.xml中的Struts核心配置文件

最后

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
2、Struts.xml中的Struts核心配置文件

最后

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

[外链图片转存中…(img-ObZBGHUE-1715537210683)]

[外链图片转存中…(img-wFewe8QT-1715537210683)]

[外链图片转存中…(img-ayanBphf-1715537210684)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值