前言
Spring與MyBatis整合的意義在于提供了一種結(jié)合優(yōu)勢(shì)的方式,以便更好地開發(fā)和管理持久層(數(shù)據(jù)庫訪問)代碼。
這里也是總結(jié)了幾點(diǎn)主要意義
-
簡(jiǎn)化配置:Spring與MyBatis整合后,可以通過Spring的配置文件來管理和配置MyBatis的相關(guān)配置,例如數(shù)據(jù)源、事務(wù)管理等,而不需要額外的獨(dú)立配置文件。這樣可以減少配置的復(fù)雜性,提高開發(fā)效率。
-
提供事務(wù)管理:Spring框架本身提供了強(qiáng)大的事務(wù)管理功能,通過與MyBatis整合,可以將MyBatis的數(shù)據(jù)庫操作納入到Spring的事務(wù)管理中,實(shí)現(xiàn)數(shù)據(jù)庫操作的事務(wù)控制,保證數(shù)據(jù)的一致性和完整性。
-
實(shí)現(xiàn)依賴注入:Spring框架的核心特性之一是依賴注入(DI),它可以幫助我們更好地管理對(duì)象之間的依賴關(guān)系。通過與MyBatis整合,可以將MyBatis的Mapper對(duì)象注入到Spring管理的Bean中,使得在業(yè)務(wù)邏輯中可以方便地使用MyBatis的數(shù)據(jù)訪問功能,而不需要手動(dòng)創(chuàng)建Mapper對(duì)象。
-
提供AOP支持:Spring框架提供了面向切面編程(AOP)的支持,可以方便地進(jìn)行日志記錄、事務(wù)管理、異常處理等橫切邏輯的封裝。通過與MyBatis整合,可以將這些橫切邏輯應(yīng)用到MyBatis的SQL執(zhí)行過程中,提供更強(qiáng)大的日志記錄、性能監(jiān)控等功能。
-
提供更好的擴(kuò)展性:通過整合Spring和MyBatis,可以更好地支持應(yīng)用程序的擴(kuò)展和維護(hù)。例如,可以利用Spring的Bean的生命周期管理,實(shí)現(xiàn)對(duì)Mapper對(duì)象的統(tǒng)一管理和釋放資源;還可以利用Spring的AOP功能,對(duì)MyBatis進(jìn)行封裝,以應(yīng)對(duì)未來需求變化和功能擴(kuò)展。
總而言之,Spring與MyBatis整合的意義在于將兩個(gè)優(yōu)秀的框架結(jié)合起來,充分發(fā)揮各自的優(yōu)勢(shì),提供更好的開發(fā)體驗(yàn)和可維護(hù)性,減少重復(fù)代碼,提高開發(fā)效率,使得持久層開發(fā)更加簡(jiǎn)單、靈活和可靠。
一.Spring與Mybatis的整合配置
1.新建Maven工程
這里就不過多介紹了,翻看主頁有詳細(xì)教程
Idea的Maven部署及常用設(shè)置_ChatYU.的博客-CSDN博客
?2.添加相關(guān)依賴
將properties和dependences中的代碼替換成下面的代碼
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target>
<maven.compiler.plugin.version>3.7.0</maven.compiler.plugin.version>
<!--添加jar包依賴-->
<!--1.spring 5.0.2.RELEASE相關(guān)-->
<spring.version>5.0.2.RELEASE</spring.version>
<!--2.mybatis相關(guān)-->
<mybatis.version>3.4.5</mybatis.version>
<!--mysql-->
<mysql.version>5.1.44</mysql.version>
<!--pagehelper分頁jar依賴-->
<pagehelper.version>5.1.2</pagehelper.version>
<!--mybatis與spring集成jar依賴-->
<mybatis.spring.version>1.3.1</mybatis.spring.version>
<!--3.dbcp2連接池相關(guān) druid-->
<commons.dbcp2.version>2.1.1</commons.dbcp2.version>
<commons.pool2.version>2.4.3</commons.pool2.version>
<!--4.log日志相關(guān)-->
<log4j2.version>2.9.1</log4j2.version>
<!--5.其他-->
<junit.version>4.12</junit.version>
<servlet.version>4.0.0</servlet.version>
<lombok.version>1.18.2</lombok.version>
</properties>
<dependencies>
<!--1.spring相關(guān)-->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-orm</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-tx</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-aspects</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-test</artifactId>
<version>${spring.version}</version>
</dependency>
<!--2.mybatis相關(guān)-->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>${mybatis.version}</version>
</dependency>
<!--mysql-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>${mysql.version}</version>
</dependency>
<!--pagehelper分頁插件jar包依賴-->
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper</artifactId>
<version>${pagehelper.version}</version>
</dependency>
<!--mybatis與spring集成jar包依賴-->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis-spring</artifactId>
<version>${mybatis.spring.version}</version>
</dependency>
<!--3.dbcp2連接池相關(guān)-->
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-dbcp2</artifactId>
<version>${commons.dbcp2.version}</version>
</dependency>
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-pool2</artifactId>
<version>${commons.pool2.version}</version>
</dependency>
<!--4.log日志相關(guān)依賴-->
<!--核心log4j2jar包-->
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-core</artifactId>
<version>${log4j2.version}</version>
</dependency>
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-api</artifactId>
<version>${log4j2.version}</version>
</dependency>
<!--web工程需要包含log4j-web,非web工程不需要-->
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-web</artifactId>
<version>${log4j2.version}</version>
</dependency>
<!--5.其他-->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>${junit.version}</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>${servlet.version}</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>${lombok.version}</version>
<scope>provided</scope>
</dependency>
</dependencies>
在指定位置將plugin插件代碼進(jìn)行替換
注:如果并不希望使用pluginManagement進(jìn)行管理插件,建議刪除
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>${maven.compiler.plugin.version}</version>
<configuration>
<source>${maven.compiler.source}</source>
<target>${maven.compiler.target}</target>
<encoding>${project.build.sourceEncoding}</encoding>
</configuration>
</plugin>
<plugin>
<groupId>org.mybatis.generator</groupId>
<artifactId>mybatis-generator-maven-plugin</artifactId>
<version>1.3.2</version>
<dependencies>
<!--使用Mybatis-generator插件不能使用太高版本的mysql驅(qū)動(dòng) -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>${mysql.version}</version>
</dependency>
</dependencies>
<configuration>
<overwrite>true</overwrite>
</configuration>
</plugin>
3. 配置文件
3.1.在resource包中配置添加以下文件
沒有resource包就新建一個(gè)
?文章來源地址http://www.zghlxwxcb.cn/news/detail-680223.html
?文件資源已整合好放在文章頂部,解壓后將其導(dǎo)入即可
?3.2 導(dǎo)入之后,開始對(duì)spring-mybatis進(jìn)行配置
將spring-mybatis的文件內(nèi)容全部進(jìn)行替換
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context" xmlns:tx="http://www.springframework.org/schema/tx"
xmlns:aop="http://www.springframework.org/schema/aop"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd">
<!--1. 注解式開發(fā) -->
<!-- 注解驅(qū)動(dòng) -->
<context:annotation-config/>
<!-- 用注解方式注入bean,并指定查找范圍:com.javaxl.ssm及子子孫孫包-->
<context:component-scan base-package="com.javaxl.ssm"/>
<context:property-placeholder location="classpath:jdbc.properties"/>
<bean id="dataSource" class="org.apache.commons.dbcp2.BasicDataSource"
destroy-method="close">
<property name="driverClassName" value="${jdbc.driver}"/>
<property name="url" value="${jdbc.url}"/>
<property name="username" value="${jdbc.username}"/>
<property name="password" value="${jdbc.password}"/>
<!--初始連接數(shù)-->
<property name="initialSize" value="10"/>
<!--最大活動(dòng)連接數(shù)-->
<property name="maxTotal" value="100"/>
<!--最大空閑連接數(shù)-->
<property name="maxIdle" value="50"/>
<!--最小空閑連接數(shù)-->
<property name="minIdle" value="10"/>
<!--設(shè)置為-1時(shí),如果沒有可用連接,連接池會(huì)一直無限期等待,直到獲取到連接為止。-->
<!--如果設(shè)置為N(毫秒),則連接池會(huì)等待N毫秒,等待不到,則拋出異常-->
<property name="maxWaitMillis" value="-1"/>
</bean>
<!--4. spring和MyBatis整合 -->
<!--1) 創(chuàng)建sqlSessionFactory-->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<!-- 指定數(shù)據(jù)源 -->
<property name="dataSource" ref="dataSource"/>
<!-- 自動(dòng)掃描XxxMapping.xml文件,**任意路徑 -->
<property name="mapperLocations" value="classpath*:com/javaxl/ssm/**/mapper/*.xml"/>
<!-- 指定別名 -->
<property name="typeAliasesPackage" value="com/javaxl/ssm/**/model"/>
<!--配置pagehelper插件-->
<property name="plugins">
<array>
<bean class="com.github.pagehelper.PageInterceptor">
<property name="properties">
<value>
helperDialect=mysql
</value>
</property>
</bean>
</array>
</property>
</bean>
<!--2) 自動(dòng)掃描com/javaxl/ssm/**/mapper下的所有XxxMapper接口(其實(shí)就是DAO接口),并實(shí)現(xiàn)這些接口,-->
<!-- 即可直接在程序中使用dao接口,不用再獲取sqlsession對(duì)象-->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<!--basePackage 屬性是映射器接口文件的包路徑。-->
<!--你可以使用分號(hào)或逗號(hào) 作為分隔符設(shè)置多于一個(gè)的包路徑-->
<property name="basePackage" value="com/javaxl/ssm/**/mapper"/>
<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>
</bean>
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource" />
</bean>
<tx:annotation-driven transaction-manager="transactionManager" />
<aop:aspectj-autoproxy/>
</beans>
替換后,將里面的java包中路徑替換成自己的路徑
?
注:只需要修改javaxl即可,后面可自行添加自己的路徑??
當(dāng)我們修改好后,打開右側(cè)導(dǎo)航欄中的Maven,雙擊標(biāo)注的紅框,如果沒有這個(gè)選項(xiàng)則說明沒有安裝這個(gè)插件,在插件庫中搜索mybatis-generator進(jìn)行安裝,建議觀看主頁
Mybatis的環(huán)境搭建及常用插件安裝https://blog.csdn.net/weixin_73320743/article/details/132393743?spm=1001.2014.3001.5502其中有常用的插件安裝詳細(xì)教程
?生成完成后不要再次點(diǎn)擊,防止覆蓋
?
?當(dāng)我們需要在Java文件中進(jìn)行測(cè)試時(shí)需要將pom.xml中的junit中的scope進(jìn)行注釋
4.通過注解將bookmapper給spring進(jìn)行管理
4.1 @Repository
當(dāng)我們將Spring與Mybatis進(jìn)行整合后加入注解后就不需要再配置JavaBean了,我們?cè)谇懊娴膕pring-mybatis整合時(shí)指定了掃描范圍
?4.2 Autowired
它可以自動(dòng)將匹配的依賴對(duì)象注入到相應(yīng)的變量、方法或構(gòu)造函數(shù)中,為我們提高get、set方法
4.3 @Data?
自動(dòng)為模型實(shí)體類提供get、set、toString方法
4.4@AllArgsConstructor@NoArgsConstructor
自動(dòng)添加有參無參構(gòu)造器
4.5@ContextConfiguration(locations={"classpath:spring-context.xml"}
自動(dòng)加載花括號(hào)中的spring上下文,搭配@RunWith(SpringJUnit4ClassRunner.class)使用
二.aop整合pageHelper分頁插件
1.創(chuàng)建Aop切面類及包
package com.YU.aspect;
import com.YU.utils.PageBean;
import com.github.pagehelper.PageHelper;
import com.github.pagehelper.PageInfo;
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 YU
* @create 2023-08-25 17:17
*/
@Aspect //代表當(dāng)前類為切面類
@Component //代表當(dāng)前類交給Spring進(jìn)行管理
public class PagerAspect {
@Around("execution(* *..*Biz.*Pager(..))")
public Object invoke(ProceedingJoinPoint args) throws Throwable {
PageBean pageBean = null;
//獲取目標(biāo)方法的所有參數(shù)
Object[] ars = args.getArgs();
for (Object param : ars) {
if(param instanceof PageBean){
pageBean = (PageBean)param;
break;
}
}
if(pageBean != null && pageBean.isPagination())
PageHelper.startPage(pageBean.getPage(),pageBean.getRows());
Object list = args.proceed();
if(null != pageBean && pageBean.isPagination()){
PageInfo pageInfo = new PageInfo((List) list);
pageBean.setTotal(pageInfo.getTotal()+"");
}
return list;
}
}
2.解析@Around環(huán)繞通知中的execution(* *..*Service.*Pager(..))
* :返回任意類型
*.. : 任意包,任意層級(jí)
*Service :以Service結(jié)尾的類/接口
*Page:以Page結(jié)尾的方法
.. :任意參數(shù)
符合上述條件即為目標(biāo)類或目標(biāo)方法
3.測(cè)試方法
@Test
public void listPager() {
Book book = new Book();
PageBean pageBean = new PageBean();
pageBean.setPage(2);
pageBean.setRows(30);
book.setBname("圣墟");
this.bookbiz.listPager(book,pageBean).forEach(System.out::println);
}
?測(cè)試結(jié)果
今日筆記分享到這里就結(jié)束了,感謝各位能看到這里,喜歡博主的可以關(guān)注哦
感謝各位老鐵的三連,謝謝謝謝謝了
文章來源:http://www.zghlxwxcb.cn/news/detail-680223.html
?
到了這里,關(guān)于Spring與Mybatis整合&&aop整合pageHelper分頁插件的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!