整合Spring和Mybatis(在整合DBCP基础上修改)

整合DBCP请参考主页文章spring整合DBCP

前期准备工作

删除dao层的实现类,只留下接口即可。

在resource文件夹下导入dao层对应的xml文件以及mybatis的核心配置文件,配置文件中只写加载映射文件的代码即可,如下所示

XML 复制代码
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
//只写映射文件的代码
    <mappers>
        <mapper resource="dao/userMapper.xml"></mapper>
    </mappers>

</configuration>

第一步

导入所需jar包

XML 复制代码
 <!--mybatis项目所需jar包-->
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.4.5</version>
        </dependency>

        <!--整合mybatis与spring需要的jar包-->
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis-spring</artifactId>
            <version>1.3.1</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-jdbc</artifactId>
            <version>5.0.2.RELEASE</version>
        </dependency>

第二步

书写核心配置文件beans.xml

XML 复制代码
<!--开启注解-->
    <context:annotation-config/>
    <!--组件扫描-->
    <context:component-scan base-package="com.xszx"></context:component-scan>
    <!--  配置数据源  -->
    <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
        <property name="driverClassName" value="com.mysql.cj.jdbc.Driver"></property>
        <property name="url" value="jdbc:mysql:///sjt2405"></property>
        <property name="username" value="root"></property>
        <property name="password" value="123456"></property>
    </bean>
    <!--创建sqlSessionFactory对象-->
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <!--注入数据源对象-->
        <property name="dataSource" ref="dataSource"></property>
        <property name="configLocation" value="mybatis-config.xml"></property>
    </bean>
    <!--创建sqlSessionTemplate对象-->
	<!--需要配置Spring专属的SqlSession,以便与当作参数传递给其他的类使用-->
	<!--sqlSessionTemplate没有无参构造,所以注入时需要使用构造方法注入-->
    <bean id="sqlSessionTemplate" class="org.mybatis.spring.SqlSessionTemplate">
        <constructor-arg name="sqlSessionFactory" ref="sqlSessionFactory"></constructor-arg>
    </bean>

第三步

将原本创建userDao的代码改成创建sqlSessionTemplate并且去读取userDao.class

java 复制代码
@Service // 控制反转的个性化注解 还有@controller、@Repository
public class UserServiceImpl implements UserService {

    private SqlSessionTemplate sqlSessionTemplate;
    @Autowired //依赖注入的注解,默认是byType,可以使用@Qualifier注解来指定名称
    public void setSqlSessionTemplate(SqlSessionTemplate sqlSessionTemplate) {
        this.sqlSessionTemplate = sqlSessionTemplate;
    }
 
    @Override
    public void addUser(User user) {
        System.out.println("完成业务");
        UserDao userDao = sqlSessionTemplate.getMapper(UserDao.class);
        userDao.add(user);
    }
}

第四步

测试

java 复制代码
//测试层
public class test {
    public static void main(String[] args) throws Exception {
        //读取核心配置文件
        BeanFactory beanFactory =  new ClassPathXmlApplicationContext("beans.xml");
        //获取bean(注解)
        UserController userController =(UserController) beanFactory.getBean("userController");
        //执行
        userController.addUser();
    }
}



//controller层
@Controller  //controller控制反转的个性化注解,通用的是@Component
public class UserController {
    User user = new User();
    UserService userServiceImpl;
    @Resource
    public void setUserServiceImpl(UserService userServiceImpl) {
        this.userServiceImpl = userServiceImpl;
    }
    
    public void addUser() throws Exception {
        user.setRole(1);
        user.setName("DBCP");
        user.setPwd("123");
        //执行
        userService.addUser(user);
    }
}
相关推荐
满昕欢喜18 分钟前
SQL Server从入门到项目实践(超值版)读书笔记 28
数据库·sql·sqlserver
AntBlack1 小时前
虽迟但到 :盘一盘 SpringAI 现在发展得怎么样了?
后端·spring·openai
ss2732 小时前
手写Spring第4弹: Spring框架进化论:15年技术变迁:从XML配置到响应式编程的演进之路
xml·java·开发语言·后端·spring
DokiDoki之父2 小时前
MyBatis—增删查改操作
java·spring boot·mybatis
兩尛2 小时前
Spring面试
java·spring·面试
我命由我123455 小时前
Spring Boot - Spring Boot 静态资源延迟响应(使用拦截器、使用过滤器、使用 ResourceResolver)
java·spring boot·后端·spring·java-ee·intellij-idea·intellij idea
DokiDoki之父9 小时前
Mybatis—入门 & (配置)SQL提示和日志输出
数据库·sql·mybatis
迦蓝叶11 小时前
JAiRouter v1.0.0 正式发布:企业级 AI 服务网关的开源解决方案
java·运维·人工智能·网关·spring·ai·开源
一叶飘零_sweeeet12 小时前
深入 Spring 内核:解密 15 种设计模式的实战应用与底层实现
java·spring·设计模式
洛克大航海12 小时前
3-SpringCloud-LoadBalancer-OpenFeign服务调用与负载均衡
spring·spring cloud·负载均衡·openfeign·loadbalancer