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等文件生成的路径

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


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

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

password="exue2018" />






配置文件结束后,执行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

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


以上就是我的分享,感谢你耐心看完文章,觉得有所收获的朋友们可以点个关注哦,想多学一点Java方面知识的朋友们,可以进我的一个后端技术群,里面收集了很多Java架构资料,大家可以进群免费领取的,群号:680075317,也可以进群一起交流,比如遇到技术瓶颈、面试不过的,大家一些交流学习!!!

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,569评论 4 363
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,499评论 1 294
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 109,271评论 0 244
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,087评论 0 209
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,474评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,670评论 1 222
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,911评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,636评论 0 202
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,397评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,607评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,093评论 1 261
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,418评论 2 254
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,074评论 3 237
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,092评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,865评论 0 196
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,726评论 2 276
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,627评论 2 270

推荐阅读更多精彩内容