• Springboot整合mybatisPlus实现分页


    package lsi.util;

    import com.baomidou.mybatisplus.generator.AutoGenerator;
    import com.baomidou.mybatisplus.generator.config.DataSourceConfig;
    import com.baomidou.mybatisplus.generator.config.GlobalConfig;
    import com.baomidou.mybatisplus.generator.config.PackageConfig;
    import com.baomidou.mybatisplus.generator.config.StrategyConfig;
    import com.baomidou.mybatisplus.generator.config.converts.MySqlTypeConvert;
    import com.baomidou.mybatisplus.generator.config.rules.DbColumnType;
    import com.baomidou.mybatisplus.generator.config.rules.DbType;
    import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;
    import com.baomidou.mybatisplus.generator.engine.FreemarkerTemplateEngine;

    /**
    * <p>
    * 代码生成器演示
    * </p>
    */
    public class MpGenerator {

    public static void main(String[] args) {
    // assert (false) : "代码生成属于危险操作,请确定配置后取消断言执行代码生成!";
    AutoGenerator mpg = new AutoGenerator();
    // 选择 freemarker 引擎,默认 Velocity
    mpg.setTemplateEngine(new FreemarkerTemplateEngine());

    // 全局配置
    GlobalConfig gc = new GlobalConfig();
    gc.setAuthor("LJH");
    gc.setOutputDir("F://project/colby/src/main/java");
    gc.setFileOverride(false);// 是否覆盖同名文件,默认是false
    gc.setActiveRecord(true);// 不需要ActiveRecord特性的请改为false
    gc.setEnableCache(false);// XML 二级缓存
    gc.setBaseResultMap(true);// XML ResultMap
    gc.setBaseColumnList(false);// XML columList
    /* 自定义文件命名,注意 %s 会自动填充表实体属性! */
    // gc.setMapperName("%sDao");
    // gc.setXmlName("%sDao");
    // gc.setServiceName("MP%sService");
    // gc.setServiceImplName("%sServiceDiy");
    // gc.setControllerName("%sAction");
    mpg.setGlobalConfig(gc);

    // 数据源配置
    DataSourceConfig dsc = new DataSourceConfig();
    dsc.setDbType(DbType.MYSQL);
    dsc.setTypeConvert(new MySqlTypeConvert() {
    // 自定义数据库表字段类型转换【可选】
    @Override
    public DbColumnType processTypeConvert(String fieldType) {
    System.out.println("转换类型:" + fieldType);
    // 注意!!processTypeConvert 存在默认类型转换,如果不是你要的效果请自定义返回、非如下直接返回。
    return super.processTypeConvert(fieldType);
    }
    });
    dsc.setDriverName("com.mysql.cj.jdbc.Driver");
    dsc.setUsername("root");
    dsc.setPassword("123456");
    dsc.setUrl("jdbc:mysql://ip:3306/colbyDB?useUnicode=true&characterEncoding=utf8");
    mpg.setDataSource(dsc);

    // 策略配置
    StrategyConfig strategy = new StrategyConfig();
    // strategy.setCapitalMode(true);// 全局大写命名 ORACLE 注意
    //strategy.setTablePrefix(new String[]{"user_"});// 此处可以修改为您的表前缀
    strategy.setNaming(NamingStrategy.nochange);// 表名生成策略
    strategy.setInclude(new String[]{"user"}); // 需要生成的表
    // strategy.setExclude(new String[]{"test"}); // 排除生成的表
    // 自定义实体父类
    // strategy.setSuperEntityClass("com.baomidou.demo.TestEntity");
    // 自定义实体,公共字段
    // strategy.setSuperEntityColumns(new String[] { "test_id", "age" });
    // 自定义 mapper 父类
    // strategy.setSuperMapperClass("com.baomidou.demo.TestMapper");
    // 自定义 service 父类
    // strategy.setSuperServiceClass("com.baomidou.demo.TestService");
    // 自定义 service 实现类父类
    // strategy.setSuperServiceImplClass("com.baomidou.demo.TestServiceImpl");
    // 自定义 controller 父类
    // strategy.setSuperControllerClass("com.baomidou.demo.TestController");
    // 【实体】是否生成字段常量(默认 false)
    // public static final String ID = "test_id";
    // strategy.setEntityColumnConstant(true);
    // 【实体】是否为构建者模型(默认 false)
    // public User setName(String name) {this.name = name; return this;}
    // strategy.setEntityBuilderModel(true);
    mpg.setStrategy(strategy);

    // 包配置
    PackageConfig pc = new PackageConfig();
    pc.setParent("com.mht.springbootmybatisplus");
    // pc.setModuleName("test");
    mpg.setPackageInfo(pc);

    // 注入自定义配置,可以在 VM 中使用 cfg.abc 【可无】
    // InjectionConfig cfg = new InjectionConfig() {
    // @Override
    // public void initMap() {
    // Map<String, Object> map = new HashMap<String, Object>();
    // map.put("abc", this.getConfig().getGlobalConfig().getAuthor() +
    // "-mp");
    // this.setMap(map);
    // }
    // };
    //
    // // 自定义 xxList.jsp 生成
    // List<FileOutConfig> focList = new ArrayList<>();
    // focList.add(new FileOutConfig("/template/list.jsp.vm") {
    // @Override
    // public String outputFile(TableInfo tableInfo) {
    // // 自定义输入文件名称
    // return "D://my_" + tableInfo.getEntityName() + ".jsp";
    // }
    // });
    // cfg.setFileOutConfigList(focList);
    // mpg.setCfg(cfg);
    //
    // // 调整 xml 生成目录演示
    // focList.add(new FileOutConfig("/templates/mapper.xml.vm") {
    // @Override
    // public String outputFile(TableInfo tableInfo) {
    // return "/develop/code/xml/" + tableInfo.getEntityName() + ".xml";
    // }
    // });
    // cfg.setFileOutConfigList(focList);
    // mpg.setCfg(cfg);
    //
    // // 关闭默认 xml 生成,调整生成 至 根目录
    // TemplateConfig tc = new TemplateConfig();
    // tc.setXml(null);
    // mpg.setTemplate(tc);

    // 自定义模板配置,可以 copy 源码 mybatis-plus/src/main/resources/templates 下面内容修改,
    // 放置自己项目的 src/main/resources/templates 目录下, 默认名称一下可以不配置,也可以自定义模板名称
    // TemplateConfig tc = new TemplateConfig();
    // tc.setController("...");
    // tc.setEntity("...");
    // tc.setMapper("...");
    // tc.setXml("...");
    // tc.setService("...");
    // tc.setServiceImpl("...");
    // 如上任何一个模块如果设置 空 OR Null 将不生成该模块。
    // mpg.setTemplate(tc);

    // 执行生成
    mpg.execute();

    // 打印注入设置【可无】
    // System.err.println(mpg.getCfg().getMap().get("abc"));
    }
    }
    ---------------------------反向生成工具类---------------------------
    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE xml>
    <configuration scan="true" scanPeriod="60 seconds" debug="false">
    <contextName>colby</contextName>
    <property name="log.path" value="log" />
    <property name="log.maxHistory" value="15" />
    <property name="log.pattern" value="%d{HH:mm:ss.SSS} %contextName [%thread] %-5level %logger{36} - %msg%n" />

    <!--输出到控制台-->
    <appender name="console" class="ch.qos.logback.core.ConsoleAppender">
    <encoder>
    <pattern>${log.pattern}</pattern>
    </encoder>
    </appender>

    <!--输出到文件-->
    <appender name="file_info" class="ch.qos.logback.core.rolling.RollingFileAppender">
    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
    <fileNamePattern>${log.path}/info/info.%d{yyyy-MM-dd}.log</fileNamePattern>
    <MaxHistory>${log.maxHistory}</MaxHistory>
    </rollingPolicy>
    <encoder>
    <pattern>${log.pattern}</pattern>
    </encoder>
    <filter class="ch.qos.logback.classic.filter.LevelFilter">
    <level>INFO</level>
    <onMatch>ACCEPT</onMatch>
    <onMismatch>DENY</onMismatch>
    </filter>
    </appender>

    <appender name="file_error" class="ch.qos.logback.core.rolling.RollingFileAppender">
    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
    <fileNamePattern>${log.path}/error/error.%d{yyyy-MM-dd}.log</fileNamePattern>
    </rollingPolicy>
    <encoder>
    <pattern>${log.pattern}</pattern>
    </encoder>
    <filter class="ch.qos.logback.classic.filter.LevelFilter">
    <level>ERROR</level>
    <onMatch>ACCEPT</onMatch>
    <onMismatch>DENY</onMismatch>
    </filter>
    </appender>

    <root level="debug">
    <appender-ref ref="console" />
    </root>

    <root level="info">
    <appender-ref ref="file_info" />
    <appender-ref ref="file_error" />
    </root>
    </configuration>
    -------------------logback-spring.xml-----------------------
    # 配置slq打印日志
    mybatis-plus.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl
    -------------------------------------------------------
    @SpringBootApplication
    @NacosPropertySource(dataId = "springboot2-nacos-config", autoRefreshed = true)
    public class ColbyApplication {

    public static void main(String[] args) {
    SpringApplication.run(ColbyApplication.class, args);
    }

    @Bean
    public PaginationInterceptor paginationInterceptor() {
    PaginationInterceptor page = new PaginationInterceptor();
    page.setDialectType("mysql");

    return page;
    }

    @Bean
    public PerformanceInterceptor performanceInterceptor() {
    PerformanceInterceptor page = new PerformanceInterceptor();
    page.setFormat(true);
    return page;
    }

    }
    -------------------需要添加-----------------------
    @RequestMapping("/queryCtionUser/{currentPage}")
    @ResponseBody
    public ResponseBo queryConditionUser(@PathVariable("currentPage")int currentPage) {
    Page<User> page = new Page<>(currentPage, 2);//这里写死了每页显示数量
    Page<User> userList = userServiceImpl.selectPage(page, new EntityWrapper<User>()
    //.between("age", 18, 50)
    .like("name", "jacck")//查询条件
    //.eq("last_name", "tom")
    );
    System.out.println(userList);
    System.out.println("================= 相关的分页信息 ==================");
    System.out.println("总条数:" + userList.getTotal());
    System.out.println("当前页码:" + userList.getCurrent());
    System.out.println("总页数:" + userList.getPages());
    System.out.println("每页显示条数:" + userList.getSize());
    System.out.println("是否有上一页:" + userList.hasPrevious());
    System.out.println("是否有下一页:" + userList.hasNext());
    //还可以将查询到的结果set进page对象中
    return ResponseBo.ok(userList);
    }
    -------------------实现代码----------------------不需要pagehelper.jar跟它无关
    http://localhost:9595/user/queryCtionUser/2
     
  • 相关阅读:
    怎么为学生布置作业
    新学期的第一节Android课
    RUCSE小组博客列表
    test
    个人最终总结
    黄金点小游戏的设计与实现
    WordCount 程序的实现
    阅读下面程序,请回答如下问题:
    Visual Studio 2015的安装和简单的单元测试
    构建之法--软件工程学习随笔之二
  • 原文地址:https://www.cnblogs.com/jiahaoJAVA/p/10832749.html
Copyright © 2020-2023  润新知