您现在的位置是:网站首页> 内容页

Spring Boot 集成 Mybatis(druid 数据库连接池 以及 分页配置)

  • 宝马线上娱乐bmw333
  • 2019-03-26
  • 387人已阅读
简介MyBatis是一款优秀的持久层框架,它支持定制化SQL、存储过程以及高级映射,目前很大一部分互联网、软件公司都在使用这套框架关于Mybatis-Generator的下载可以到这个

MyBatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射,目前很大一部分互联网、软件公司都在使用这套框架

关于Mybatis-Generator的下载可以到这个地址:https://github.com/mybatis/generator/releases,

下来来之后,我们主要关注几个文件

配置文件:generator.properties

主要是数据库的相关配置,以及文件生成的根路径

generator.jdbc.driver=com.mysql.jdbc.Drivergenerator.jdbc.url=jdbc:mysql://192.168.xxx.xxx:4596/ek?useUnicode=true&characterEncoding=utf8generator.jdbc.username=root#u6570u636eu5e93u5bc6u7801uff0cu4e0du8981u52a0u5bc6uff01uff01uff01generator.jdbc.password=ek2018#u6570u636eu5e93u540dgenerator.jdbc.database=ek#u8868u7684u524du7f00generator.jdbc.tablePrefix=t_#u751fu6210u7684packageu7ed3u6784generator.package.name=com.ek#u751fu6210u5230u7684u9879u76eeu7684u6839u8defu5f84uff0cu4f8bu5982uff1au751fu6210u5230u9879u76eeexue-authcenter-webu4e0bu65f6uff0cu53efu4ee5u8fd9u4e48u914du7f6euff1a#generator.target.rootPath=E:/MLCS_HQB/workspace/git/exuePlat/exue-authcenter/exue-authcenter-webgenerator.target.rootPath=E:/WorkSpace/eke/code-generator

generatorConfig.xml

这里主要是引用配置文件里的数据库配置,标明model、MapperXml、Mapper等文件生成的路径

<table>标签里写需要生成文件的表有哪些

<!-- 数据库连接 --> <jdbcConnection driverClass="${generator.jdbc.driver}" connectionURL="${generator.jdbc.url}" userId="${generator.jdbc.username}" password="exue2018" /> <!-- model生成 --> <javaModelGenerator targetPackage="com.exue.dao.model" targetProject="E:/WorkSpace/eLearning/exue-eLearning/exue-code-generator/src/main/java" /> <!-- MapperXML生成 --> <sqlMapGenerator targetPackage="com.exue.dao.mapper" targetProject="E:/WorkSpace/eLearning/exue-eLearning/exue-code-generator/src/main/java" /> <!-- Mapper接口生成 --> <javaClientGenerator targetPackage="com.exue.dao" targetProject="E:/WorkSpace/eLearning/exue-eLearning/exue-code-generator/src/main/java" type="XMLMAPPER" /> <!-- 需要映射的表 --> <!-- 需要映射的表 --> <table tableName="t_user_base" domainObjectName="UserBase"></table>

配置文件结束后,执行Generator.java里的main方法,刷新项目,就ok了

在现在中,我们可能需要对生成的文件内容做一些额外的配置,那就根据具体需求在模板文件里修改

该要的文件都有了,放到项目中的特定包下

下面看下pom.xml需要加哪些依赖包

<dependency> <groupId>com.alibaba</groupId> <artifactId>druid</artifactId> <version>1.1.0</version> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.41</version> </dependency> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>1.3.1</version></dependency><!--mapper--><dependency> <groupId>tk.mybatis</groupId> <artifactId>mapper-spring-boot-starter</artifactId> <version>1.2.4</version></dependency><!--pagehelper--><dependency> <groupId>com.github.pagehelper</groupId> <artifactId>pagehelper-spring-boot-starter</artifactId> <version>1.2.3</version></dependency>  

包括了mysql数据驱动,Mybatis的启动包,数据库连接池druid相关依赖

 

打开Spring Boot启动类,在类上添加注解@MapperScan("com.example.demo.mapper"),记得要扫描mapper接口

@SpringBootApplication@MapperScan("com.example.demo.mapper")public class DemoApplication { public static void main(String[] args) { SpringApplication.run(DemoApplication.class, args); }}

 

 

然后来看下mysql的配置,打开application.properties

#datasourcespring.datasource.url=jdbc:mysql://192.168.128.183:4596/eke?useUnicode=true&characterEncoding=UTF-8&useSSL=falsespring.datasource.username=rootspring.datasource.password=exue2018spring.datasource.driver-class-name=com.mysql.jdbc.Driverspring.datasource.druid.initial-size=1spring.datasource.druid.min-idle=5spring.datasource.druid.max-active=20spring.datasource.druid.max-wait-millis=60000#mybatismybatis.type-aliases-package=com.example.demo.pojomybatis.mapper-locations=classpath:mapper/*.xml#pagehelperpagehelper.helperDialect=mysqlpagehelper.reasonable=truepagehelper.supportMethodsArguments=truepagehelper.params=count=countSql

第一部分是dataSource的配置,包括了数据库地址,库名,用户名,密码以及相关数据库连接池的配置

第二部分是Mybatis的配置,包括自定义pojo的包路径,不需要加classpath:  以及Mapper xml的路径

第三部分是分页的相关配置

在service层定义接口pageUserBase ,最后返回是以分页的形式展现

PageResult<UserBaseDTO> pageUserBase(UserBaseDTO searchCondition, Pagination page) throws Exception;

怎么去实现这个分页显示

@Override public PageResult<UserBaseDTO> pageUserBase(UserBaseDTO userBaseDTO, Pagination page) throws Exception { // TODO Auto-generated method stub PageHelper.startPage(page.getPage(),page.getRows()); UserBaseExample UserBaseExamle = new UserBaseExample(); UserBaseExamle.setOrderByClause("p_id DESC"); List<UserBase> listUserBase = userBaseMapper.selectByExample(UserBaseExamle); List<UserBaseDTO> listUserBaseDTO = new ArrayList<UserBaseDTO>(); for(UserBase ub :listUserBase){ UserBaseDTO ubd = new UserBaseDTO(); ubd.setpId(ub.getpId()); ubd.setsPassword(ub.getsPassword()); ubd.setsPhone(ub.getsPhone()); listUserBaseDTO.add(ubd); } Pagination pagination = new Pagination(); pagination = SqlUtil.generatePagination(listUserBase); return new PageResult<>(listUserBaseDTO, pagination); }

PageHelper.startPage(page.getPage(),page.getRows());获取客户端传来的页码和一页显示记录数

Pagination pagination = new Pagination();pagination = SqlUtil.generatePagination(listUserBase);根据最后返回的list进行分页处理返回到controller层后,进行ResponseMsg的封装后,返回客户端

PageResult<UserBaseDTO> res = null; List<UserBaseDTO> list = null; UserBaseDTO ubt = new UserBaseDTO(); try { StringBuffer logOut = new StringBuffer(); logOut.append(""); logOut.append("cjq2测试"); logOut.append(""); LOGGER.debug(logOut.toString()); Pagination page = new Pagination(); page.setPage(1); page.setRows(10);; res = iUserbaseService.pageUserBase(ubt, page); list = res.getList(); } catch (Exception e) { // TODO: handle exception throw new BaseException("数据错误"); //LOGGER.error(e.getMessage()); } return new ResponseMsg(requestMsg.getRoute(), GeneralConstant.SUCCESS, "查询成功", res);

启动SpringBoot项目

 

 

, 1, 0, 9);

文章评论

Top