《一线大厂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}
======================================================================================
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核心架构进阶知识点整理》,全部都是精华中的精华,本着共赢的心态,好东西自然也是要分享的
内容颇多,篇幅却有限,这就不在过多的介绍了,大家可根据以上截图自行脑补
《一线大厂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面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》,点击传送门,即可获取!