• 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
    #u6570u636eu5e93u5bc6u7801uff0cu4e0du8981u52a0u5bc6uff01uff01uff01
    generator.jdbc.password=ek2018
    
    #u6570u636eu5e93u540d
    generator.jdbc.database=ek
    #u8868u7684u524du7f00
    generator.jdbc.tablePrefix=t_
    
    #u751fu6210u7684packageu7ed3u6784
    generator.package.name=com.ek
    
    #u751fu6210u5230u7684u9879u76eeu7684u6839u8defu5f84uff0cu4f8bu5982uff1au751fu6210u5230u9879u76eeexue-authcenter-webu4e0bu65f6uff0cu53efu4ee5u8fd9u4e48u914du7f6euff1a
    #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>标签里写需要生成文件的表有哪些

    <!-- 数据库连接 -->
            <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

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

     
    
    
    
  • 相关阅读:
    关于JAVA的线程问题
    Java 对JTextField添加回车响应
    Failed to install *.apk on device 'emulator-5554': timeout .
    静态属性
    类与对象的实例属性

    面向对象2
    面向对象设计
    re模块,主要用来查询
    xml对标签操作,
  • 原文地址:https://www.cnblogs.com/qiyuan880794/p/9835746.html
Copyright © 2020-2023  润新知