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

struts>

/queryAll.jsp

queryAll

13、Mybatis-config.xml Mybatis核心配置文件

14、queryAll.jsp

<%@page contentType=“text/html; UTF-8” pageEncoding=“utf-8” isELIgnored=“false” %>

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

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

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

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

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

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

img

最后

笔者已经把面试题和答案整理成了面试专题文档

image

image

image

image

image

image

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

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

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

img

最后

笔者已经把面试题和答案整理成了面试专题文档

[外链图片转存中…(img-J1XsAN1E-1713499911781)]

[外链图片转存中…(img-g3sIkoVp-1713499911783)]

[外链图片转存中…(img-qoFp6SDn-1713499911784)]

[外链图片转存中…(img-kkgNBkDI-1713499911789)]

[外链图片转存中…(img-6JwJKVrO-1713499911791)]

[外链图片转存中…(img-8tjfXQCj-1713499911792)]

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

Logo

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

更多推荐