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

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

我们主要关注几个文件

配置文件:generator.properties

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

generator.jdbc.driver=com.mysql.jdbc.Driver

generator.jdbc.url=jdbc:mysql://192.168.xxx.xxx:4596/ek?useUnicode=true&characterEncoding=utf8

generator.jdbc.username=root

#\u6570\u636e\u5e93\u5bc6\u7801\uff0c\u4e0d\u8981\u52a0\u5bc6\uff01\uff01\uff01

generator.jdbc.password=ek2018

#\u6570\u636e\u5e93\u540d

generator.jdbc.database=ek

#\u8868\u7684\u524d\u7f00

generator.jdbc.tablePrefix=t_

#\u751f\u6210\u7684package\u7ed3\u6784

generator.package.name=com.ek

#\u751f\u6210\u5230\u7684\u9879\u76ee\u7684\u6839\u8def\u5f84\uff0c\u4f8b\u5982\uff1a\u751f\u6210\u5230\u9879\u76eeexue-authcenter-web\u4e0b\u65f6\uff0c\u53ef\u4ee5\u8fd9\u4e48\u914d\u7f6e\uff1a

#generator.target.rootPath=E:/MLCS_HQB/workspace/git/exuePlat/exue-authcenter/exue-authcenter-web

generator.target.rootPath=E:/WorkSpace/eke/code-generator

generatorConfig.xml

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

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

connectionURL="${generator.jdbc.url}"

userId="${generator.jdbc.username}"

password=“exue2018” />

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

在现在中,我们可能需要对生成的文件内容做一些额外的配置,那就根据具体需求在模板文件里修改.在此我向大家推荐一个架构学习交流圈。交流学习伪鑫:1253431195(里面有大量的面试题及答案)里面会分享一些资深架构师录制的视频录像:有Spring,MyBatis,Netty源码分析,高并发、高性能、分布式、微服务架构的原理,JVM性能优化、分布式架构等这些成为架构师必备的知识体系。还能领取免费的学习资源,目前受益良多

image

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

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

com.alibaba

druid

1.1.0

mysql

mysql-connector-java

5.1.41

org.mybatis.spring.boot

mybatis-spring-boot-starter

1.3.1

tk.mybatis

mapper-spring-boot-starter

1.2.4

com.github.pagehelper

pagehelper-spring-boot-starter

1.2.3

包括了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

#datasource

spring.datasource.url=jdbc:mysql://192.168.128.183:4596/eke?useUnicode=true&characterEncoding=UTF-8&useSSL=false

spring.datasource.username=root

spring.datasource.password=exue2018

spring.datasource.driver-class-name=com.mysql.jdbc.Driver

spring.datasource.druid.initial-size=1

spring.datasource.druid.min-idle=5

spring.datasource.druid.max-active=20

spring.datasource.druid.max-wait-millis=60000

#mybatis

mybatis.type-aliases-package=com.example.demo.pojo

mybatis.mapper-locations=classpath:mapper/*.xml

#pagehelper

pagehelper.helperDialect=mysql

pagehelper.reasonable=true

pagehelper.supportMethodsArguments=true

pagehelper.params=count=countSql

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

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

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

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

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

怎么去实现这个分页显示

@Override

public PageResult 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 listUserBase = userBaseMapper.selectByExample(UserBaseExamle);

List listUserBaseDTO = new ArrayList();

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 res = null;

List list = null;

UserBaseDTO ubt = new UserBaseDTO();

try {

StringBuffer logOut = new StringBuffer();

logOut.append("\n");

logOut.append(“cjq2测试”);

logOut.append("\n");

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项目

image

以上就是我的分享,感谢你耐心看完文章,觉得有所收获的朋友们可以点个关注哦

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值