Mybatis与Spring集成配置

目录

具体操作

1.1.添加依赖

1.2创建spring的配置文件

1.3. 注解式开发

 Aop整合pagehelper插件

1. 创建一个AOP切面

2. @Around("execution(* *..*xxx.*xxx(..))") 表达式解析

                  Mybatis与Spring集成配置_第1张图片

 

前言:

上篇我们讲解了关于Mybatis的分页,今天我们讲Mybatis与Spring集成配置。

特别提示:

关于数据库连接池的解释

会初始化N个数据库链接对象10个,当用户需要请求需要操作数据库时,那么直接数据库连接池中获取链接,用完会放回连接池中。

为什么要使用连接池

数据库连接是一种关键的有限的昂贵的资源,这一点在多用户的网页应用程序中体现得尤为突出。  一个数据库连接对象均对应一个物理数据库连接,每次操作都打开一个物理连接,使用完都关闭连接,这样造成系统的 性能低下。 数据库连接池的解决方案是在应用程序启动时建立足够的数据库连接,并讲这些连接组成一个连接池(简单说:在一个“池”里放了好多半成品的数据库联接对象),由应用程序动态地对池中的连接进行申请、使用和释放。对于多于连接池中连接数的并发请求,应该在请求队列中排队等待。并且应用程序可以根据池中连接的使用率,动态增加或减少池中的连接数。 连接池技术尽可能多地重用了消耗内存地资源,大大节省了内存,提高了服务器地服务效率,能够支持更多的客户服务。通过使用连接池,将大大提高程序运行效率,同时,我们可以通过其自身的管理机制来监视数据库连接的数量、使用情况等。 
 

lombok

能够便捷的使用实体类。

具体操作

1.1.添加依赖

今天我们要新建一个工程项目,找到对应的 pom文件。

Mybatis与Spring集成配置_第2张图片

1.1 添加spring相关依赖 {从properties开始copy到dependencies


    UTF-8
    1.8
    1.8
    3.7.0

    
    
    5.0.2.RELEASE
    
    3.4.5
    
    5.1.44
    
    5.1.2
    
    1.3.1
    
    2.1.1
    2.4.3
    
    2.9.1
    
    4.12
    4.0.0
    1.18.2




    
    
        org.springframework
        spring-context
        ${spring.version}
    
    
        org.springframework
        spring-orm
        ${spring.version}
    
    
        org.springframework
        spring-tx
        ${spring.version}
    
    
        org.springframework
        spring-aspects
        ${spring.version}
    
    
        org.springframework
        spring-web
        ${spring.version}
    
    
        org.springframework
        spring-test
        ${spring.version}
    

    
    
        org.mybatis
        mybatis
        ${mybatis.version}
    
    
    
        mysql
        mysql-connector-java
        ${mysql.version}
    
    
    
        com.github.pagehelper
        pagehelper
        ${pagehelper.version}
    
    
    
        org.mybatis
        mybatis-spring
        ${mybatis.spring.version}
    

    
    
        org.apache.commons
        commons-dbcp2
        ${commons.dbcp2.version}
    
    
        org.apache.commons
        commons-pool2
        ${commons.pool2.version}
    

    
    
    
        org.apache.logging.log4j
        log4j-core
        ${log4j2.version}
    
    
        org.apache.logging.log4j
        log4j-api
        ${log4j2.version}
    
    
    
        org.apache.logging.log4j
        log4j-web
        ${log4j2.version}
    

    
    
        junit
        junit
        ${junit.version}
        test
    
    
        javax.servlet
        javax.servlet-api
        ${servlet.version}
        provided
    
    
        org.projectlombok
        lombok
        ${lombok.version}
        provided
    


2.新建resources的文件


    
    
        src/main/java
        
            **/*.xml
        
    
    
    
        src/main/resources
        
            jdbc.properties
            *.xml
        
    

如图:注意是在自带的build中添加resources

Mybatis与Spring集成配置_第3张图片

3.添加plugin插件(逆向生成插件)



    org.apache.maven.plugins
    maven-compiler-plugin
    ${maven.compiler.plugin.version}
    
        ${maven.compiler.source}
        ${maven.compiler.target}
        ${project.build.sourceEncoding}
    


    org.mybatis.generator
    mybatis-generator-maven-plugin
    1.3.2
    
        
        
            mysql
            mysql-connector-java
            ${mysql.version}
        
    
    
        true
    

放置在plugins中

注意是添加,不是覆盖,原有的plugin不用变

Mybatis与Spring集成配置_第4张图片

还要去掉锁定插件管理(没有用到当前的工程中)

点击生成改变 

 Mybatis与Spring集成配置_第5张图片

出现这个插件应该是成功配置了!

Mybatis与Spring集成配置_第6张图片

1.2创建spring的配置文件

创建spring的核心配置文件 (spring-context.xml)

Mybatis与Spring集成配置_第7张图片

与上面一样的创建spring的整合的配置文件 (spring-mybatis.xml)

继续将整合的文件放入到核心配置中

Mybatis与Spring集成配置_第8张图片

配置spring-mybatis的类



    
    
    
    
    

    

    
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
    

    
    
    
        
        
        
        
        
        
        
        
            
                
                    
                        
                            helperDialect=mysql
                        
                    
                
            
        
    

    
    
    
        
        
        
        
    

    
        
    
    
    


1.3. 注解式开发

自动扫描com.lya下的文件,但是需要标记哦

Mybatis与Spring集成配置_第9张图片

注掉scope的代码:原因是注掉了可以在java中去测式

Mybatis与Spring集成配置_第10张图片

标记要交给spring管理的类

BookMapper类标记

@Repository

Mybatis与Spring集成配置_第11张图片

BookBizImpl类标记

@Service

Mybatis与Spring集成配置_第12张图片

BookBiz中添加标记

 @RunWith(SpringJUnit4ClassRunner.class)

@ContextConfiguration(locations={"classpath:spring-context.xml"}) 

Mybatis与Spring集成配置_第13张图片

Book中构建使用lombok

@Data//===set,get,tosting
@AllArgsConstructor//有参
@NoArgsConstructor//无参

@Autowired:用于自动装配依赖关系。通过该注解,可以将一个对象自动注入到另一个对象中,省去了手动配置依赖关系的步骤。

@RunWith 是 JUnit 框架中的一个注解,它用于指定运行测试类的运行器(Runner)。运行器是 JUnit 框架的一部分,它负责执行测试类中的测试方法,并提供额外的功能和扩展。

@ContextConfiguration 是 Spring 框架中的一个注解,它用于指定测试类或测试方法运行时的 Spring 上下文配置。它告诉测试框架在运行测试之前加载指定的 Spring 配置文件或配置类,并创建相应的 Spring 上下文。 
 

Mybatis与Spring集成配置_第14张图片

运行结果:

Mybatis与Spring集成配置_第15张图片

 Aop整合pagehelper插件

使用AOP编程解决分页代码重复的问题

1. 创建一个AOP切面

package com.lya.aspect;

import com.github.pagehelper.PageHelper;
import com.github.pagehelper.PageInfo;
import com.lya.utils.PageBean;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.springframework.stereotype.Component;

import java.util.List;

/**
 * @author 程序猿-小李哥
 * @site www.xiaolige.com
 * @company 猪八戒有限集团
 * @create 2023-08-25-17:35
 */
@Aspect
@Component
public class PagerAspect {

    @Around("execution(* *..*biz.*Pager(..))")
    public Object invoke(ProceedingJoinPoint args) throws Throwable {
        Object[] params = args.getArgs();
        PageBean pageBean = null;
        for (Object param : params) {
            if(param instanceof PageBean){
                pageBean = (PageBean)param;
                break;
            }
        }

        if(pageBean != null && pageBean.isPagination())
            PageHelper.startPage(pageBean.getPage(),pageBean.getRows());

        Object list = args.proceed(params);

        if(null != pageBean && pageBean.isPagination()){
            PageInfo pageInfo = new PageInfo((List) list);
            pageBean.setTotal(pageInfo.getTotal()+"");
        }
        return list;
    }

}

BookBiz

    List listPager(Book book , PageBean pageBean);

2. @Around("execution(* *..*xxx.*xxx(..))") 表达式解析

@Around("execution(* *..*Biz.*Pager2(..))") 这个表达式是一个切点表达式,用于定义一个切点,以便在使用 AspectJ 或 Spring AOP 进行方法拦截时进行匹配。

@Around:这是一个通知类型的注解,表示在目标方法执行前后都会执行通知逻辑。
"execution(* *..* Service.*Pager(..))":这是切点表达式的一部分,用于匹配符合条件的方法。具体解释如下:
execution:表示匹配方法的执行。
*:表示匹配任意返回类型。
*..*:表示匹配任意包名和子包名。
Biz:表示匹配包含 "Biz" 字符串的类名。
*pagePager2:表示匹配以 "pagePager2" 结尾的方法名。
(..):表示匹配任意参数列表。
        综合起来,这个切点表达式的含义是:匹配任意返回类型、任意包名和子包名下的包含 "Service" 字符串的类中以 "Pager" 结尾的方法,并在这些方法执行前后执行通知逻辑。
 

运行:

Mybatis与Spring集成配置_第16张图片

你可能感兴趣的:(spring,java,后端,mybatis,数据库)