MybatisPlus常用方法 分页page,范围查询between,模糊查询like,条件查询eq,ne,gt,排序 orderBy以及MybatisPlus生成代码等

  • //查询所有
 List<PmsProduct> list1 = pmsProductService.list(new QueryWrapper<PmsProduct>());
  • //根据条件查询 eq
 List<PmsProduct> list2 = pmsProductService.list(new QueryWrapper<PmsProduct>().eq("id",2));
  • //关键字查询 like // 左 likelift %t ,右 likeRight t% //notLike不包含
 List<PmsProduct> list3 = pmsProductService.list(new QueryWrapper<PmsProduct>().eq("id",2).like("name","小王"));
  • //排序 orderBy
 List<PmsProduct> list4 = pmsProductService.list(new QueryWrapper<PmsProduct>().eq("id",2).like("name","小王").orderByDesc("age"));
  • //不等于 ne 大于gt 大于等于ge 小于lt
 List<PmsProduct> list5 = pmsProductService.list(new QueryWrapper<PmsProduct>().eq("id",2).like("name","小王").orderByDesc("age").ne("name","www"));
  • 查询不为空的某字段 isNotNull
List<PmsProduct> list1 = pmsProductService.list(Wrappers.<PmsProduct>lambdaQuery().isNotNull(PmsProduct::getBrandName));
  • //分页page
 Page<PmsProduct> pmsProductPage = pmsProductService.page(new Page<PmsProduct>(1, 10), new QueryWrapper<>(new PmsProduct()));
  • //筛选对像的某一个具体属性 select
Integer countyId = sysAreaService.getObj(new QueryWrapper<SysArea>().select("id").eq("name", location.getCity()), o -> (Integer) o);
  • //在某个范围内 between
// 分页查询 10 条姓名为‘张三’、性别为男,且年龄在18至50之间的用户记录
List<User> userList = userMapper.selectPage(
        new Page<User>(1, 10),
        new EntityWrapper<User>().eq("name", "张三")
                .eq("sex", 0)
                .between("age", "18", "50")
);
  • 根据某个属性批量查询
pmsProductService.getObj(Wrappers.<PmsProduct>lambdaQuery().in(PmsProduct::getId, productIds).select(PmsProduct::getOutProductId), o -> (List<Long>) o);

代码自动生成

// 代码自动生成器
public class generateCode {
   public static void main(String[] args) {
    // 需要构建一个 代码自动生成器 对象
    AutoGenerator mpg = new AutoGenerator();
    // 配置策略
    // 1、全局配置
    GlobalConfig gc = new GlobalConfig();
    String projectPath = System.getProperty("user.dir");
    gc.setOutputDir(projectPath+"/src/main/java");
    gc.setAuthor("kwhua");//作者名称
    gc.setOpen(false);
    gc.setFileOverride(false); // 是否覆盖
    gc.setIdType(IdType.ID_WORKER);
    gc.setDateType(DateType.ONLY_DATE);
    gc.setSwagger2(true);//实体属性 Swagger2 注解

    // 自定义文件命名,注意 %s 会自动填充表实体属性!
    gc.setServiceName("%sService"); 
    gc.setControllerName("%sController");
    gc.setServiceName("%sService");
    gc.setServiceImplName("%sServiceImpl");
    gc.setMapperName("%sMapper");
    gc.setXmlName("%sMapper");

    mpg.setGlobalConfig(gc);

    //2、设置数据源
    DataSourceConfig dsc = new DataSourceConfig();
    dsc.setUrl("jdbc:mysql://localhost:3306/kwhua_test?
useSSL=false&useUnicode=true&characterEncoding=utf-8&serverTimezone=GMT%2B8");
    dsc.setDriverName("com.mysql.cj.jdbc.Driver");
    // dsc.setDriverName("com.mysql.jdbc.Driver"); //mysql5.6以下的驱动
    dsc.setUsername("root");
    dsc.setPassword("root");
    dsc.setDbType(DbType.MYSQL);
    mpg.setDataSource(dsc);
    //3、包的配置
    PackageConfig pc = new PackageConfig();
    pc.setParent("com.kwhua"); //包名
    pc.setModuleName("model"); //模块名
    pc.setEntity("entity");
    pc.setMapper("mapper");
    pc.setService("service");
    pc.setController("controller");
    mpg.setPackageInfo(pc);

    //4、策略配置
    StrategyConfig strategy = new StrategyConfig();
    strategy.setInclude("user","course"); // 设置要映射的表名
    strategy.setNaming(NamingStrategy.underline_to_camel);
    strategy.setColumnNaming(NamingStrategy.underline_to_camel);
    strategy.setEntityLombokModel(true); // 自动lombok;
    strategy.setLogicDeleteFieldName("deleted");
    // 自动填充配置
    TableFill gmtCreate = new TableFill("gmt_create", FieldFill.INSERT);
    TableFill gmtModified = new TableFill("gmt_modified",FieldFill.INSERT_UPDATE);
    ArrayList<TableFill> tableFills = new ArrayList<>();
    tableFills.add(gmtCreate);
    tableFills.add(gmtModified);
    strategy.setTableFillList(tableFills);
    // 乐观锁
    strategy.setVersionFieldName("version");
    //根据你的表名来建对应的类名,如果你的表名没有下划线,比如test,那么你就可以取消这一步
    strategy.setTablePrefix("t_");
    strategy.setRestControllerStyle(true); //rest请求
    //自动转下划线,比如localhost:8080/hello_id_2
    strategy.setControllerMappingHyphenStyle(true); 
    mpg.setStrategy(strategy);
    mpg.execute(); //执行
 }
}

更多用法前往MybatisPlus官方文档

你可能感兴趣的:(mybatis,mysql,java,数据库)