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

MyBatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射,目前很大一部分互联网、软件公司都在使用这套框架 关于Mybatis-Generator的下载可以到这个地址:https://github.com/mybatis/generator/releases, 下来来之后,我们主要关注几个文件 配置文件: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等文件生成的路径 标签里写需要生成文件的表有哪些 复制代码
复制代码 配置文件结束后,执行Generator.java里的main方法,刷新项目,就ok了 在现在中,我们可能需要对生成的文件内容做一些额外的配置,那就根据具体需求在模板文件里修改 该要的文件都有了,放到项目中的特定包下 下面看下pom.xml需要加哪些依赖包 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 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项目 分类: Spring Boot开发常用技https://www.cnblogs.com/qiyuan880794/p/9835746.html术整合 好文要顶
50000+
5万行代码练就真实本领
17年
创办于2008年老牌培训机构
1000+
合作企业
98%
就业率

联系我们

电话咨询

0532-85025005

扫码添加微信