MyBatisPlus性能分析插件,條件構造器,程式碼自動生成器詳解
- 2020 年 8 月 7 日
- 筆記
- mybatisPlus
性能分析插件
我們在平時的開發中,會遇到一些慢sql,測試,
druid
MP(MyBatisPlus)也提供性能分析插件,如果超過這個時間就停止
不過官方在3.2版本的時候取消了,原因如下
條件構造器
十分重要:
Wrapper
我們寫一些複雜查詢的時候
首先創建一個測試類
@SpringBootTest
public class MyBatisPlusWrapperTest {
@Autowired
private AirMapper airMapper;
}
// 查詢一些用戶:
// 查詢一下pm10為22且monitoring_station不為空的用戶,
@Test
public void test1(){
QueryWrapper<Air> wrapper = new QueryWrapper<>();
wrapper.isNotNull("monitoring_station")//資料庫中的名字,而不是實體類中的名字
.eq("pm10",22);
List<Air> airList = airMapper.selectList(wrapper);//可以對比下map的查詢
airList.forEach(System.out::println);//循環遍歷輸出
}
//查詢單個用戶
@Test
public void test2() {
QueryWrapper<Air> wrapper = new QueryWrapper<>();
wrapper.eq("id",222);
airMapper.selectOne(wrapper);
}
//Butween And
//查詢pm25在40-60之間的用戶和數量
@Test
public void test3() {
QueryWrapper<Air> wrapper = new QueryWrapper<>();
wrapper.between("pm25",40,60);//區間
airMapper.selectList(wrapper).forEach(System.out::println);
System.out.println(airMapper.selectCount(wrapper));//查詢結果數
}
//模糊查詢
//查詢monitor_station中帶"站"的,切不帶"哈"的
@Test
public void test4() {
QueryWrapper<Air> wrapper = new QueryWrapper<>();
wrapper.like("monitoring_station","站").notLike("monitoring_station","哈");
airMapper.selectList(wrapper).forEach(System.out::println);
}
//查詢以哈開頭切以站結尾的 哈% %站
@Test
public void test5() {
QueryWrapper<Air> wrapper = new QueryWrapper<>();
wrapper.likeLeft("monitoring_station","站").likeRight("monitoring_station","哈");
airMapper.selectList(wrapper).forEach(System.out::println);
}
//嵌入sql查詢
@Test
public void test6() {
QueryWrapper<Air> wrapper = new QueryWrapper<>();
wrapper.inSql("district_id","select id from air where district_id = id");
airMapper.selectObjs(wrapper).forEach(System.out::println);
}
//多表查詢
//通過id進行排序
@Test
public void test7() {
QueryWrapper<Air> wrapper = new QueryWrapper<>();
wrapper.orderByDesc("id");
airMapper.selectList(wrapper).forEach(System.out::println);
}
程式碼生成器
導入依賴
在
3.0.3
版本以後程式碼生成器需要手動添加依賴
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-generator</artifactId>
<version>3.3.2</version>
</dependency>
根據前端的模板引擎導入相應依賴(我沒寫前端頁面就隨便導入了一個
velocity
的)記住一定要加入其中一個,否則會報錯
具體配置程式碼
package com.cloudcentury.mybatis;
import com.baomidou.mybatisplus.annotation.DbType;
import com.baomidou.mybatisplus.annotation.FieldFill;
import com.baomidou.mybatisplus.annotation.IdType;
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.po.TableFill;
import com.baomidou.mybatisplus.generator.config.rules.DateType;
import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;
import java.util.ArrayList;
/**
* ClassName:臭狗屎王溥松
* Package:com.cloudcentury.mybatis
*
* @date:2020/8/7 10:22
* @author:[email protected] Description:
*/
public class CodeAuto {
public static void main(String[] args) {
//需要構建一個程式碼自動生成器對象
AutoGenerator ag = new AutoGenerator();//程式碼生辰器對象
//配置執行策略
//1.全局配置
GlobalConfig gc = new GlobalConfig();//全局配置對象
String property = System.getProperty("user.dir");//獲取項目名稱
System.out.println(property);
gc.setOutputDir(property+"/src/main/java");//設置程式碼存放路徑
gc.setAuthor("臭狗屎");//設置作者
gc.setOpen(false);//設置是否打開資源管理器(生成完畢後)
gc.setFileOverride(false);//是否覆蓋程式碼
gc.setServiceName("%sService");//去掉Service的I前綴
gc.setIdType(IdType.AUTO);//設置id自動生成類型
gc.setDateType(DateType.ONLY_DATE);//日期時間,僅僅時間
gc.setSwagger2(false);//是否設置swagger
ag.setGlobalConfig(gc);//將全局配置放到裡面
//設置數據源
DataSourceConfig desc = new DataSourceConfig();//數據源配置對象
//設置url
desc.setUrl("jdbc:mysql://localhost:3306/air?characterEncoding=utf8&serverTimezone=GMT");
desc.setDriverName("com.mysql.cj.jdbc.Driver");//設置驅動
desc.setUsername("root");//設置用戶名
desc.setPassword("12345");//設置密碼
desc.setDbType(DbType.MYSQL);//設置資料庫類型
ag.setDataSource(desc);//將數據源放到裡面
//包的配置
//說白了就是說需要生成那些包,叫什麼
PackageConfig pc = new PackageConfig();//包配置對象
pc.setModuleName("com");//模組名字
pc.setParent("com.cloudcentury");//父模組名字
pc.setEntity("entity");//Entity包的名字
pc.setMapper("mapper");//mapper包的名字
pc.setService("service");//service包的名字
pc.setController("controller");//controller包的名字
ag.setPackageInfo(pc);//將包的配置放到裡面
//策略配置
StrategyConfig sc = new StrategyConfig();
sc.setInclude("air","district"); //設置要映射的表名,這個一定要設置的
sc.setNaming(NamingStrategy.underline_to_camel);//設置名字下劃線轉大寫
sc.setColumnNaming(NamingStrategy.underline_to_camel);//設置列明下劃線轉大寫
sc.setEntityLombokModel(true);//自動生成lombok
sc.setLogicDeleteFieldName("deleted");//邏輯刪除的名字
//自動填充配置
TableFill monitor_time = new TableFill("monitor_time", FieldFill.INSERT);//執行插入是更新時間
TableFill last_modify_time = new TableFill("last_modify_time", FieldFill.INSERT);//執行更新時執行的操作
ArrayList<TableFill> tableFills = new ArrayList<>();//創建一個List
tableFills.add(monitor_time);
tableFills.add(last_modify_time);
sc.setTableFillList(tableFills);//這裡只有這一個用list的方法
sc.setVersionFieldName("version"); //樂觀鎖的配置
sc.setRestControllerStyle(true);//開啟rest式的駝峰命名
sc.setControllerMappingHyphenStyle(true);//下劃線命名:localhost:8080/hello_id_2
ag.setStrategy(sc);//策略配置對象
ag.execute();//執行
}
}