美文网首页IT必备技能
Spring Boot 集成Mybatis(druid 数据库连

Spring Boot 集成Mybatis(druid 数据库连

作者: 架构师Javaspring | 来源:发表于2019-08-02 18:16 被阅读6次

    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,也可以进群一起交流,比如遇到技术瓶颈、面试不过的,大家一些交流学习!!!

    相关文章

      网友评论

        本文标题:Spring Boot 集成Mybatis(druid 数据库连

        本文链接:https://www.haomeiwen.com/subject/kerrdctx.html