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开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

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

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

最后

无论是哪家公司,都很重视基础,大厂更加重视技术的深度和广度,面试是一个双向选择的过程,不要抱着畏惧的心态去面试,不利于自己的发挥。同时看中的应该不止薪资,还要看你是不是真的喜欢这家公司,是不是能真的得到锻炼。

针对以上面试技术点,我在这里也做一些分享,希望能更好的帮助到大家。

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
本涵盖了95%以上Java开发知识点,真正体系化!**

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

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

最后

无论是哪家公司,都很重视基础,大厂更加重视技术的深度和广度,面试是一个双向选择的过程,不要抱着畏惧的心态去面试,不利于自己的发挥。同时看中的应该不止薪资,还要看你是不是真的喜欢这家公司,是不是能真的得到锻炼。

针对以上面试技术点,我在这里也做一些分享,希望能更好的帮助到大家。

[外链图片转存中…(img-wKdZ7sBd-1713499874841)]

[外链图片转存中…(img-2SU4FkpG-1713499874842)]

[外链图片转存中…(img-bpKsSYrZ-1713499874843)]

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

Logo

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。

更多推荐