目录
一、集成
1.1 集成的概述
1.2 集成的优点
1.3 代码示例
二、整合
2.1 整合概述
2.2 整合进行分页
- 集成是指将不同的组件、部分或系统组合在一起,以形成一个整体功能完整的解决方案。它是通过连接、交互和协调组件之间的关系来实现的。
- 集成可以应用于各个领域,包括软件开发、系统设计、电子设备、工程项目等。它的目标是将不同的元素融合在一起,以实现更高的效率、更好的功能和更好的用户体验。
- 在软件开发中,集成指的是将不同的软件模块、组件或服务集成到一个完整的应用程序中。这种集成可以通过应用程序接口(API)或集成工具来实现,使不同的模块能够相互通信、交换数据和共享功能。
- 在系统设计中,集成指的是将不同的系统元素、硬件或软件组件集成到一个完整的系统中。这种集成可以涉及物理连接、通信协议的兼容性、数据传输和协调运行等方面,以确保系统的正常运行和协作。
- 在电子设备中,集成指的是将多个功能和组件整合到一个设备中,以实现多样化的功能和便利性。例如,智能手机集成了电话、相机、浏览器、音乐播放器等多个功能,使用户可以在一个设备上完成多项任务。
- 在工程项目中,集成指的是将不同的工程部分或子系统集成到一个整体项目中。这种集成需要进行设计、测试和调试,以确保各个部分之间的协调和一致性,最终实现项目的成功完成。
总之,集成是将不同的组件、部分或系统组合在一起,以形成一个完整、协调和功能完备的解决方案的过程。通过集成,可以提高效率、共享资源和提升整体性能。
集成的优点包括:
提高效率:集成不同的组件或系统可以消除重复的工作和冗余的步骤,从而提高整体效率。通过协调和串联各个部分,可以实现更快的工作流程和更高的生产力。
增强功能:通过集成不同的功能模块或服务,可以实现更多样化和综合化的功能。这可以提供更好的用户体验和满足用户的多样化需求。
优化资源利用:集成可以共享和优化资源的利用,减少资源的浪费和重复投入。通过共享数据库、设备和服务,可以提高资源的利用率,降低成本。
提升系统性能:集成可以弥补单个组件或系统的不足,提升整体系统的性能。通过整合不同的部分,可以实现优化的协作和相互补充,提高整体系统的性能和稳定性。
实现数据共享和互联:通过集成不同的数据源和系统,可以实现数据的共享和互操作。这可以促进信息的流动和共享,提高决策的准确性和效率。
简化管理和维护:集成可以将不同的组件或系统整合到一个统一的管理平台或界面中,简化管理和维护的任务。这使得管理人员可以更方便地监控和控制整个系统。
总的来说,集成的优点包括提高效率、增强功能、优化资源利用、提升系统性能、实现数据共享和简化管理。通过集成,可以实现更高的效益和更好的用户体验。
首先创建一个maven项目 名称为 Spring-mybatis。
然后在找到项目中pom.xml配置文件,配置引用插件,pom.xml配置如下 :
4.0.0
org.example
Spring-mybatis
1.0-SNAPSHOT
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}
javax.servlet
javax.servlet-api
${servlet.version}
provided
org.projectlombok
lombok
${lombok.version}
provided
Spring-mybatis
src/main/java
**/*.xml
src/main/resources
jdbc.properties
*.xml
org.apache.maven.plugins
maven-compiler-plugin
${maven.compiler.plugin.version}
${maven.compiler.target}
${project.build.sourceEncoding}
org.mybatis.generator
mybatis-generator-maven-plugin
1.3.2
mysql
mysql-connector-java
${mysql.version}
true
maven-clean-plugin
3.1.0
maven-resources-plugin
3.0.2
maven-compiler-plugin
3.8.0
maven-surefire-plugin
2.22.1
maven-war-plugin
3.2.2
maven-install-plugin
2.5.2
maven-deploy-plugin
2.8.2
然后创建 log4j2.xml 配置文件,并且进行配置, 配置如下 :
/root/workspace/lucenedemo/logs
/root/workspace/lucenedemo/logs/error
/root/workspace/lucenedemo/logs/warn
%d{yyyy-MM-dd HH:mm:ss.SSS} [%t-%L] %-5level %logger{36} - %msg%n
创建 jdbc.properties 文件辅助mysql数据库的连接
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://47.100.191.44:3308/mybatis_ssm?useUnicode=true&characterEncoding=UTF-8
jdbc.username=test01
jdbc.password=test01
创建 generatorConfig.xml 配置文件,用来引用插件自动生成类,接口,xml配置文件
创建 spring-context.xml 配置文件,用来配置文件加载到spring的上下文,配置如下 :
创建 spring-mybatis.xml 配置文件,用来spring和MyBatis整合及自动识别类及方法:
helperDialect=mysql
然后我们就可以自动生成代码了,如下:
为生成的增删改查进行测试,我们创建一个接口名为 : BookBiz(跟自动生成的接口一致代码)
package com.Kissship.biz;
import com.Kissship.model.Book;
import com.Kissship.utils.PageBean;
import java.util.List;
/**
* @author Kissship
*/
public interface BookBiz {
int deleteByPrimaryKey(Integer bid);
int insert(Book record);
int insertSelective(Book record);
Book selectByPrimaryKey(Integer bid);
int updateByPrimaryKeySelective(Book record);
int updateByPrimaryKey(Book record);
}
创建一个实现类实现自己创建的接口 名称为 : BookBizImpl
package com.Kissship.biz.impl;
import com.Kissship.biz.BookBiz;
import com.Kissship.mapper.BookMapper;
import com.Kissship.model.Book;
import com.Kissship.utils.PageBean;
import com.github.pagehelper.PageHelper;
import com.github.pagehelper.PageInfo;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.List;
import java.util.Map;
/**
* @author Kissship
*/
@Service
public class BookBizImpl implements BookBiz {
//相当于set及get
@Autowired
private BookMapper bookMapper;
private Book book;
private PageBean pageBean;
@Override
public int deleteByPrimaryKey(Integer bid) {
return bookMapper.deleteByPrimaryKey(bid);
}
@Override
public int insert(Book record) {
return bookMapper.insert(record);
}
@Override
public int insertSelective(Book record) {
return bookMapper.insertSelective(record);
}
@Override
public Book selectByPrimaryKey(Integer bid) {
return bookMapper.selectByPrimaryKey(bid);
}
@Override
public int updateByPrimaryKeySelective(Book record) {
return bookMapper.updateByPrimaryKeySelective(record);
}
@Override
public int updateByPrimaryKey(Book record) {
return bookMapper.updateByPrimaryKey(record);
}
}
鼠标放到BookBizImpl 按Alt+Enter(回车键) 创建测试类
名称为 : BookBizImplTest 进行方法的测试
package com.Kissship.biz.impl;
import com.Kissship.biz.BookBiz;
import com.Kissship.model.Book;
import com.Kissship.utils.PageBean;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
import static org.junit.Assert.*;
/**
* @author Kissship
*/
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations={"classpath:spring-context.xml"})
public class BookBizImplTest {
@Autowired
private BookBiz bookBiz;
@Before
public void setUp() throws Exception {
}
@After
public void tearDown() throws Exception {
}
@Test
public void deleteByPrimaryKey() {
System.out.println(bookBiz.deleteByPrimaryKey(1));
}
@Test
public void insertSelective() {
int i = bookBiz.insertSelective(new Book(1, "压力怪", 99.9f));
System.out.println(i);
}
@Test
public void selectByPrimaryKey() {
System.out.println(bookBiz.selectByPrimaryKey(63));
}
@Test
public void updateByPrimaryKeySelective() {
int i = bookBiz.updateByPrimaryKeySelective(new Book(1, "压力怪", 999.9f));
//修改后进行查看
System.out.println(bookBiz.selectByPrimaryKey(1));
}
}
效果:
AOP(面向切面编程)和PageHelper插件的整合可以提供更加灵活和便捷的分页功能。下面是一些使用AOP整合PageHelper插件的好处:
1. 代码解耦:通过AOP将分页逻辑与业务逻辑分离,使得代码更加清晰和可维护。不需要在每个需要分页的方法中手动添加分页代码,而是通过AOP切面统一处理。
2. 代码复用:通过AOP切面,可以将分页逻辑抽象成一个可复用的切面,可以在多个方法中共享该切面,减少了代码的冗余。
3. 统一管理:通过AOP切面,可以将分页逻辑集中管理,方便对分页行为进行统一的配置和修改。例如,可以在切面中设置默认的分页参数,或者根据不同的业务需求进行不同的分页配置。
4. 简化开发:通过AOP整合PageHelper插件,可以简化开发人员的工作量。不需要在每个分页方法中手动调用PageHelper的相关方法,而是通过AOP自动拦截并添加分页逻辑。
总之,通过AOP整合PageHelper插件可以提高代码的可维护性、可复用性和可读性,减少了代码的冗余,简化了开发流程,提高了开发效率
创建一个分页工具类 名为 : PageBean
package com.Kissship.utils;
import java.io.Serializable;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
public class PageBean implements Serializable {
private static final long serialVersionUID = 2422581023658455731L;
//页码
private int page=1;
//每页显示记录数
private int rows=10;
//总记录数
private int total=0;
//是否分页
private boolean isPagination=true;
//上一次的请求路径
private String url;
//获取所有的请求参数
private Map map;
public PageBean() {
super();
}
//设置请求参数
public void setRequest(HttpServletRequest req) {
String page=req.getParameter("page");
String rows=req.getParameter("rows");
String pagination=req.getParameter("pagination");
this.setPage(page);
this.setRows(rows);
this.setPagination(pagination);
this.url=req.getContextPath()+req.getServletPath();
this.map=req.getParameterMap();
}
public String getUrl() {
return url;
}
public void setUrl(String url) {
this.url = url;
}
public Map getMap() {
return map;
}
public void setMap(Map map) {
this.map = map;
}
public int getPage() {
return page;
}
public void setPage(int page) {
this.page = page;
}
public void setPage(String page) {
if(null!=page&&!"".equals(page.trim()))
this.page = Integer.parseInt(page);
}
public int getRows() {
return rows;
}
public void setRows(int rows) {
this.rows = rows;
}
public void setRows(String rows) {
if(null!=rows&&!"".equals(rows.trim()))
this.rows = Integer.parseInt(rows);
}
public int getTotal() {
return total;
}
public void setTotal(int total) {
this.total = total;
}
public void setTotal(String total) {
this.total = Integer.parseInt(total);
}
public boolean isPagination() {
return isPagination;
}
public void setPagination(boolean isPagination) {
this.isPagination = isPagination;
}
public void setPagination(String isPagination) {
if(null!=isPagination&&!"".equals(isPagination.trim()))
this.isPagination = Boolean.parseBoolean(isPagination);
}
/**
* 获取分页起始标记位置
* @return
*/
public int getStartIndex() {
//(当前页码-1)*显示记录数
return (this.getPage()-1)*this.rows;
}
/**
* 末页
* @return
*/
public int getMaxPage() {
int totalpage=this.total/this.rows;
if(this.total%this.rows!=0)
totalpage++;
return totalpage;
}
/**
* 下一页
* @return
*/
public int getNextPage() {
int nextPage=this.page+1;
if(this.page>=this.getMaxPage())
nextPage=this.getMaxPage();
return nextPage;
}
/**
* 上一页
* @return
*/
public int getPreivousPage() {
int previousPage=this.page-1;
if(previousPage<1)
previousPage=1;
return previousPage;
}
@Override
public String toString() {
return "PageBean [page=" + page + ", rows=" + rows + ", total=" + total + ", isPagination=" + isPagination
+ "]";
}
}
在自动生成的BookMapper.xml配置动态SQL中进行增加一个动态SQL
增加一下动态SQL
在自动生成的接口中增加以下代码,创建这个动态SQL的方法
List
BookPage(Book book); 在自己创建的接口 (BookBiz) 中增加以下方法
List
BookPage(Book book, PageBean pageBean); 在自己创建的实现类中重写方法
@Override public List
BookPage(Book book, PageBean pageBean) { return bookMapper.BookPage(book); } 我们创建一个 名为 PagerAspect 的切面类 代码如下 :
package com.Kissship.aspect; import com.Kissship.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 Kissship */ @Component @Aspect public class PagerAspect { /** * *..*Service.*Page(..) * * : 任何返回值 * *.. : 任何包,不限层级 * *Biz : 以Biz结尾的类或者接口 * *Pager : 以Pager结尾的方法 * (..) : 方法里有任意参数 * 符合上述条件,即为目标类或者方法 */ @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; } }
解释:
@Around("execution(* *..*Biz.*Pager(..))")
其中的 * *..*Service.*Pager(..) 以下为讲解
* : 任何返回值
*.. : 任何包,不限层级
*Biz : 以Biz结尾的类或者接口
*Pager : 以Pager结尾的方法
(..) : 方法里有任意参数
最后在测试类 ( BookBizImplTest ) 中 测试该方法,测试方法的代码如下
@Test
public void bookPage() {
Book book = new Book();
book.setBname("圣墟");
PageBean pageBean = new PageBean();
pageBean.setPage(2);
pageBean.setRows(20);
bookBiz.BookPage(book,pageBean).forEach(System.out::println);
}
效果:
最后Spring与Mybatis集成且Aop整合就到这里,祝大家在敲代码的路上一路通畅!
感谢大家的观看 !