天天看點

MyBatisPlus(四)性能分析插件 | 條件構造器 | 代碼生成器

文章目錄

    • 一、性能分析插件
      • 1、導入插件
      • 2、 測試使用
    • 二、條件構造器
      • 1、ge、gt、le、It、isNull、isNotNull
      • 2、eq、ne
      • 3、between、notBetween
      • 4、like、noLike、likeLeft、likeRight
      • 5、orderBy、orderByDesc、orderByAsc
      • 6、inSql
      • 7、last
      • 8、指定查詢的列
    • 三、代碼生成器
      • 1、導入MP 坐标
      • 2、導入資料庫配置
      • 3、MyBatisPlusConfig配置類
      • 4、代碼生成器類

一、性能分析插件

我們在平時的開發彙總,會遇到一些慢SQL。

作用:性能分析攔截器,用于輸出每條SQL語句及其執行時間。

MP也提供了性能分析插件,如果超過這個時間就停止運作。

1、導入插件

// SQL 執行效率插件
@Bean
@Profile({"dev","test"})// 設定 dev、test環境開啟,保證我們的效率
public PerformanceInterceptor performanceInterceptor(){
    PerformanceInterceptor performanceInterceptor =new PerformanceInterceptor();
    performanceInterceptor.setMaxTime(100);// ms  設定SQL執行的最大時間,如果超過了則就不執行
    performanceInterceptor.setFormat(true);// 是否格式化代碼
    return performanceInterceptor;
}
           

注意: 要在SprinBoot 中配置環境為

dev

或者

test

環境。

# 設定開發環境 dev、test、prod
spring.profiles.active=dev
           

2、 測試使用

@Test
void contextLoads() {
    // 查詢一個 Wrapper, 條件構造器,這裡我們不用null
    // 查詢全部使用者
    List<User> users = userMapper.selectList(null);
    users.forEach(System.out::println);
}
           
MyBatisPlus(四)性能分析插件 | 條件構造器 | 代碼生成器

使用性能分析插件,可以幫助我們提高效率。

二、條件構造器

十分重要:Wrapper

MyBatisPlus(四)性能分析插件 | 條件構造器 | 代碼生成器

Wrapper:條件構造抽象類,最頂端父類

  • AbstractWrapper:用于查詢條件封裝,生成sql的 where條件
    • QueryWrapper:Entity對象封裝操作類,不是用lambda文法
    • UpdateWrapper : Update條件封裝,用于Entity對象更新操作
  • AbstractLambdaWrapper:Lambda文法使用Wrapper統一處了解析lambda擷取column
    • LambdaQueryWrapper:看名稱也能明白就是用于Lambda文法使用的查詢Wrapper
    • LambdaUpdateWrapper:Lambda更新封裝Wrapper

我們寫一些複雜的SQL就可以使用它們來替代。

MyBatisPlus(四)性能分析插件 | 條件構造器 | 代碼生成器

1、ge、gt、le、It、isNull、isNotNull

@SpringBootTest
public class WrapperTest {

    @Autowired
    private UserMapper userMapper;

    // 條件查詢
    @Test
    void contextLoads() {
        // 查詢 name 不為空的使用者,并且郵箱不為空的使用者,年齡大于等于12
        QueryWrapper<User> wrapper = new QueryWrapper<>();
        wrapper
                .isNotNull("name")
                .isNotNull("email")
                .ge("age","12");
        userMapper.selectList(wrapper).forEach(System.out::println);// 和我們學習的 Map 對于以下
    }
}
           

SQL語句:

SELECT id,name,age,email,version,deleted,create_time,update_time

FROM user

WHERE deleted=0

AND name IS NOT NULL

AND email IS NOT NULL

AND age > ‘12’

2、eq、ne

注意:selectOne傳回的是一條實體記錄,當出現多條記錄會報錯

// 條件查詢
@Test
 public void test2() {
     // 查詢名字為 Billie
     QueryWrapper<User> wrapper = new QueryWrapper<>();
     wrapper.eq("name","Billie");
     User user = userMapper.selectOne(wrapper);// 查詢一個資料,出現多個結果使用List,或者Map
     System.out.println(user);
 }
           

SQL語句:

SELECT id,name,age,email,version,deleted,create_time,update_time

FROM user

WHERE deleted=0

AND name = ‘Billie’

3、between、notBetween

// 條件查詢
@Test
public void test3() {
     // 查詢年齡在20 - 30 歲之間的使用者
     QueryWrapper<User> wrapper = new QueryWrapper<>();
     wrapper.between("age",20,30);
     Integer count = userMapper.selectCount(wrapper);
     System.out.println(count);
 }
           

SQL:

SELECT COUNT(1)

FROM user

WHERE deleted=0

AND age BETWEEN 20 AND 30

4、like、noLike、likeLeft、likeRight

// 模糊查詢
@Test
public void test4() {
    // 查詢名字中不包含e,郵箱中以t開頭的
    QueryWrapper<User> wrapper = new QueryWrapper<>();
    // 左和右   %a%
    wrapper
            .notLike("name","e")
            .likeRight("email","t");  // t%
    List<Map<String, Object>> maps = userMapper.selectMaps(wrapper);
    maps.forEach(System.out::println);
}
           

SQL語句:

SELECT id,name,age,email,version,deleted,create_time,update_time

FROM user

WHERE deleted=0

AND name NOT LIKE ‘%e%’

AND name LIKE ‘t%’

5、orderBy、orderByDesc、orderByAsc

@Test
public void test7() {
    QueryWrapper<User> wrapper = new QueryWrapper<>();
    // 通過id進行排序
    wrapper.orderByDesc("id");

    List<User> users = userMapper.selectList(wrapper);
    users.forEach(System.out::println);
}
           

6、inSql

//組合查詢
@Test
public void test6() {
    QueryWrapper<User> wrapper = new QueryWrapper<>();
    wrapper.inSql("id","select id from user where id <3");

    List<Object> objects = userMapper.selectObjs(wrapper);
    objects.forEach(System.out::println);
}
           

SQL語句:

SELECT id,name,age,email,version,deleted,create_time,update_time

FROM user

WHERE deleted=0

AND id IN(select id from user where id < 3)

7、last

直接拼接到sql的最後

注意:隻能調用一次,多次調用以最後一次為準,有sql注入的風險,請謹慎使用

@Test
public void test7() {
    QueryWrapper<User> wrapper = new QueryWrapper<>();
    // 通過id進行排序
    wrapper.last("limit 1");

    List<User> users = userMapper.selectList(wrapper);
    users.forEach(System.out::println);
}
           

SQL:

SELECT id,name,age,email,version,deleted,create_time,update_time

FROM user WHERE deleted 0 limit 1

8、指定查詢的列

@Test
public void test7() {
    QueryWrapper<User> wrapper = new QueryWrapper<>();
    // 通過id進行排序
    wrapper.select("id","name","age");

    List<User> users = userMapper.selectList(wrapper);
    users.forEach(System.out::println);
}
           

SQL:

SELECT id,name,age

FROM user

WHERE deleted=0

三、代碼生成器

dao、pojo、service、controller都給我們自己編寫完成。

AutoGenerator 是 MyBatis-Plus 的代碼生成器,通過 AutoGenerator 可以快速生成 Entity、Mapper、Mapper XML、Service、Controller 等各個子產品的代碼,極大的提升了開發效率。

1、導入MP 坐标

<!--mybatis-plus-->
<dependency>
     <groupId>com.baomidou</groupId>
     <artifactId>mybatis-plus-boot-starter</artifactId>
     <version>3.0.5</version>
 </dependency>
           

2、導入資料庫配置

# 服務端口
server.port=9000
# 設定開發環境
spring.profiles.active=dev
# 禁止模闆緩存
spring.thymeleaf.cache=false

# mysql 5 驅動不同 com.mysql.jdbc.Driver
spring.datasource.username=root
spring.datasource.password=123456
spring.datasource.url=jdbc:mysql://localhost:3306/starSea99_community?useSSL=false&useUnicode=true&characterEncoding=utf-8
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
# mysql 8 驅動不同 com.mysql.cj.jdbc.Driver,需要增加時區的配置 serverTimezone=GMT%2B8

# 配置日志
mybatis-plus.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl

# 配置邏輯删除
mybatis-plus.global-config.db-config.logic-delete-value=1
mybatis-plus.global-config.db-config.logic-not-delete-value=0
           

3、MyBatisPlusConfig配置類

// 添加 @MapperScan 注解,掃描 Mapper 檔案夾
@MapperScan("com.kuang.mapper")
@EnableTransactionManagement
@Configuration//配置類
public class MyBatisPlusConfig {
    //注冊樂觀鎖插件
    @Bean
    public OptimisticLockerInterceptor optimisticLockerInterceptor() {
        return new OptimisticLockerInterceptor();
    }

    //分頁插件
    @Bean
    public PaginationInterceptor paginationInterceptor(){
        return new PaginationInterceptor();
    }

    //邏輯删除元件
    @Bean
    public ISqlInjector sqlInjector(){
        return  new LogicSqlInjector();
    }

    // SQL 執行效率插件
    @Bean
    @Profile({"dev","test"})// 設定 dev、test環境開啟,保證我們的效率
    public PerformanceInterceptor performanceInterceptor(){
        PerformanceInterceptor performanceInterceptor =new PerformanceInterceptor();
        performanceInterceptor.setMaxTime(1000);// ms  設定SQL執行的最大時間,如果超過了則就不執行
        performanceInterceptor.setFormat(true);// 是否格式化代碼
        return performanceInterceptor;
    }
}
           

4、代碼生成器類

//代碼生成器
public class KuangCode {

    public static void main(String[] args) {
        // 代碼生成器
        AutoGenerator mpg = new AutoGenerator();
        // 配置政策

        // 全局配置
        GlobalConfig gc = new GlobalConfig();
        String projectPath = System.getProperty("user.dir");
        gc.setOutputDir(projectPath + "/src/main/java");
        gc.setAuthor("StarSea99");  // 設定作者
        gc.setOpen(false);  // 是否打開檔案夾
        gc.setFileOverride(false); //是否覆寫
        gc.setServiceName("%sService");    // 去掉Service 的I字首
        gc.setIdType(IdType.ID_WORKER);
        gc.setDateType(DateType.ONLY_DATE);
        gc.setSwagger2(true);
        mpg.setGlobalConfig(gc);

        // 資料源配置
        DataSourceConfig dsc = new DataSourceConfig();
        dsc.setUrl("jdbc:mysql://localhost:3306/mybatis_plus?useSSL=false&useUnicode=true&characterEncoding=utf-8");
        dsc.setDriverName("com.mysql.jdbc.Driver");
        dsc.setUsername("root");
        dsc.setPassword("123456");
        dsc.setDbType(DbType.MYSQL);
        mpg.setDataSource(dsc);

        // 包配置
        PackageConfig pc = new PackageConfig();
        pc.setModuleName("blog");
        pc.setParent("com.kuang");
        pc.setEntity("entity");
        pc.setMapper("mapper");
        pc.setService("service");
        pc.setController("controller");
        mpg.setPackageInfo(pc);

        // 政策配置
        StrategyConfig strategy = new StrategyConfig();
        strategy.setInclude("user");// 單個表映射,設定要映射的表名,隻需要修改這裡
        //strategy.setInclude("blog","blog_tags","course","links","sys_settings","user","user_course","user_record","user_say");
        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");
        // 開啟駝峰命名格式
        strategy.setRestControllerStyle(true);
        strategy.setControllerMappingHyphenStyle(true);// localhost:8080/hello_id_2

        mpg.setStrategy(strategy);

        mpg.execute();// 執行
    }
}
           

部分效果圖

MyBatisPlus(四)性能分析插件 | 條件構造器 | 代碼生成器

如果有收獲!!! 希望老鐵們來個三連,點贊、收藏、轉發。

創作不易,别忘點個贊,可以讓更多的人看到這篇文章,順便鼓勵我寫出更好的部落格

繼續閱讀