mybatis批量删除Batch delete(1)

本文详细解析了Mybatis中批量删除用户的方法,涉及数组和集合的区别,以及如何在Struts2项目中集成Mybatis并实现批量删除功能。同时提到了Java面试中可能涉及的核心架构知识点准备。
摘要由CSDN通过智能技术生成

《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门,即可获取!

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核心配置文件

Java核心架构进阶知识点

面试成功其实都是必然发生的事情,因为在此之前我做足了充分的准备工作,不单单是纯粹的刷题,更多的还会去刷一些Java核心架构进阶知识点,比如:JVM、高并发、多线程、缓存、Spring相关、分布式、微服务、RPC、网络、设计模式、MQ、Redis、MySQL、设计模式、负载均衡、算法、数据结构、kafka、ZK、集群等。而这些也全被整理浓缩到了一份pdf——《Java核心架构进阶知识点整理》,全部都是精华中的精华,本着共赢的心态,好东西自然也是要分享的

image

image

image

内容颇多,篇幅却有限,这就不在过多的介绍了,大家可根据以上截图自行脑补
《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门,即可获取!
filter-name>

/*

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

Java核心架构进阶知识点

面试成功其实都是必然发生的事情,因为在此之前我做足了充分的准备工作,不单单是纯粹的刷题,更多的还会去刷一些Java核心架构进阶知识点,比如:JVM、高并发、多线程、缓存、Spring相关、分布式、微服务、RPC、网络、设计模式、MQ、Redis、MySQL、设计模式、负载均衡、算法、数据结构、kafka、ZK、集群等。而这些也全被整理浓缩到了一份pdf——《Java核心架构进阶知识点整理》,全部都是精华中的精华,本着共赢的心态,好东西自然也是要分享的

[外链图片转存中…(img-0stf0bG7-1714708481942)]

[外链图片转存中…(img-rOgG5E8T-1714708481942)]

[外链图片转存中…(img-K9ecII78-1714708481942)]

内容颇多,篇幅却有限,这就不在过多的介绍了,大家可根据以上截图自行脑补
《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门,即可获取!

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值