更新時間:2022-11-04 11:02:51 來源:動力節點 瀏覽1619次
(1)批量刪除功能實現示意圖
(2)Mybatis批量刪除注意事項:
1)Mybatis刪除這里主要考慮兩種參數類型:數組或者集合.
而這點區別主要體現在UserDaoMapper.xml文件中標簽的collection屬性 :
當collection=”array “時,表名參數為數組;
當collection=”list “時,表名參數為集合.
2)UserDaoMapper.xml 配置
無論Mybatis是與mysql數據庫結合,還是與Oracle數據庫,都同樣適合如下設置與操作.
<!-- 批量刪除用戶信息 -->
<delete id="BatchDelete">
delete from t_user where id
<foreach collection="list" open="in( " item="id" separator="," close=")">
#{id}
</foreach>
</delete>
<!--
t_user : 表名
id : 字段名
collection:表示類型,這里參數是數組,就寫成array,如果是集合,就寫成list
item : 是一個變量名,自己隨便起名
-->
(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 [email protected]
* @Address 天津
* @Description:
*/
public class MybatisUtil {
/**
* 線程綁定對象,保證是同一個對象
*/
private static final ThreadLocal<SqlSession> 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<User> selectUserAll();
/**
* 根據id進行批量刪除
* @param ids
*/
public void BatchDelete(List<Integer> ids);
}
(7)UserDaoMapper.xml實現
<mapper namespace="com.tjcu.dao.UserDao">
<select id="selectUserAll" resultType="user">
select *
from t_user;
</select>
<!-- 批量刪除用戶信息 -->
<delete id="BatchDelete">
delete from t_user where id
<foreach collection="list" open="in( " item="id" separator="," close=")">
#{id}
</foreach>
</delete>
<!-- 參數說明 -->
<!--
t_user : 表名
id : 字段名
collection:表示類型,這里參數是數組,就寫成array,如果是集合,就寫成list
item : 是一個變量名,自己隨便起名
-->
</mapper>
(8)UserService接口
public interface UserService {
/**
* 查詢所有
* @return
*/
public List<User> queryAll();
/**
* 批量刪除
* @param ids
*/
public void BatchDelete(List<Integer> ids);
}
(9)UserServiceImpl實現
public class UserServiceImpl implements UserService{
@Override
public List<User> queryAll() {
//調用DAO
UserDao mapper = (UserDao) MybatisUtil.getMapper(UserDao.class);
List<User> users = mapper.selectUserAll();
MybatisUtil.close();
return users;
}
@Override
public void BatchDelete(List<Integer> 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<User> users;
private List<Integer> 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<User> getUsers() {
return users;
}
public void setUsers(List<User> users) {
this.users = users;
}
public List<Integer> getIds() {
return ids;
}
public void setIds(List<Integer> ids) {
this.ids = ids;
}
}
(11)Struts2的Web.xml過濾配置【WEB-IF下】
<filter>
<filter-name>struts</filter-name>
<filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>struts</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
(12)Struts.xml中的Struts核心配置文件
struts>
<package name="user" extends="struts-default" namespace="/user">
<action name="queryAll" class="com.tjcu.action.UserAction" method="selectAll">
<result name="success" type="dispatcher">/queryAll.jsp</result>
</action>
<action name="BatchDelete" class="com.tjcu.action.UserAction" method="BatchDelete">
<result name="batachDeleteOK" type="redirectAction">
queryAll
</result>
</action>
</package>
</struts>
(13)Mybatis-config.xml Mybatis核心配置文件
<configuration>
<!--用于加載小配置文件 resource:小配置文件的文件路徑-->
<properties resource="jdbc.properties"></properties>
<!--配置別名-->
<typeAliases>
<typeAlias type="com.tjcu.entity.User" alias="user"></typeAlias>
</typeAliases>
<!--環境設置 mysql default:框架當前默認使用哪個環境設置 書寫的是環境的id屬性值-->
<environments default="mysql">
<!--單個數據庫連接配置 id:名字 隨意 唯一-->
<environment id="mysql">
<!--設置事務管理方式 JDBC:使用原生JDBC事務控制方式 JPA分布式事務控制-->
<transactionManager type="JDBC"></transactionManager>
<!--連接池設置 type:指定使用連接池的類型 POOLED:Mybatis框架默認連接池
三方連接池:DBCP 、c3p0、druid(阿里旗下)-->
<dataSource type="POOLED">
<!--數據庫的連接參數-->
<property name="driver" value="${driver}"/>
<property name="url" value="${url}"/>
<property name="username" value="${username}"/>
<property name="password" value="${password}"/>
</dataSource>
</environment>
</environments>
<!-- 配置mappers-->
<mappers>
<mapper resource="com/tjcu/dao/UserDaoImpl.xml"></mapper>
</mappers>
</configuration>
(14)queryAll.jsp
<%@page contentType="text/html; UTF-8" pageEncoding="utf-8" isELIgnored="false" %>
<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt" %>
<html>
<style>
td,th {
/*設置邊框*/
border: 1px solid black;
}
</style>
<body>
<center>
<table style=" border: 1px solid black;border-collapse: collapse;">
<%--
private Integer id;
private String username;
private String password;
private int age;
private Date birthday;
--%>
<tr>
<td>序號</td>
<td>id</td>
<td>姓名</td>
<td>密碼</td>
<td>年齡</td>
<td>生日</td>
<td>刪除</td>
<td>修改</td>
</tr>
<form action="${pageContext.request.contextPath}/user/BatchDelete" method="post">
<c:forEach var="user" items="${requestScope.users}">
<tr>
<td><input type="checkbox" name="ids" value="${user.id}"/></td>
<td>${user.id}</td>
<td>${user.username}</td>
<td>${user.password}</td>
<td>${user.age}</td>
<td><fmt:formatDate value="${user.birthday}" pattern="yyyy年MM月dd日"></fmt:formatDate></td>
<td>刪除</td>
<td>修改</td>
</tr>
</c:forEach>
<input type="submit" value="批量刪除">
</form>
</table>
</center>
</body>
</html>
0基礎 0學費 15天面授
有基礎 直達就業
業余時間 高薪轉行
工作1~3年,加薪神器
工作3~5年,晉升架構
提交申請后,顧問老師會電話與您溝通安排學習