配置日志
我們所有的
sql
在mybatisplus
是不可見的,所以在開發中需要配置日志,開發完成后,就可以取消日志了,因為日志也是損耗資源的
#配置日志
mybatis-plus:
configuration:
log-impl: org.apache.ibatis.logging.stdout.StdOutImpl #僅控制台輸出的日志
配置完日志后,后面的學習就需要注意自動生成的SQL,相信你們會喜歡上MybatisPlus
CRUD使用
Insert插入
//測試插入
@Test
public void testInsert(){
Air air = new Air();
air.setDistrictId(4);
air.setLastModifyTime(new Date());
air.setMonitoringStation("哈哈哈哈哈哈");
air.setMonitorTime(new Date());
air.setPm10(33);
air.setPm25(65);
airMapper.insert(air);
System.out.println(air);
}
這里可以看出系統幫我們自動生成了一個
id
因為我數據庫設置的自增的,我把自增取消
再看一下插入結果,發現標紅了,因為默認會插入0為主鍵的id,我之前有一個0所以插入失敗
有的人的id如果是Lang類型的可能會默認插入很長的一段數字作為id,這里是雪花算法所生成的隨機數,全球唯一(全局唯一id)
對應數據庫中的主鍵(uuid,自增id,雪花算法,redis,zookeeper)
主鍵生成策略
Twitter
的snowflake
算法(雪花算法)
snowflake
是
設置主鍵
要想設置主鍵的增加方式可以加入注解@TableId
,因為是枚舉類所以后面有很多方式
更新操作
//測試更新
@Test
public void testUpdate(){
Air air = new Air();
air.setId(9L);
air.setDistrictId(4);
air.setLastModifyTime(new Date());
air.setMonitoringStation("哈");
air.setMonitorTime(new Date());
air.setPm10(33);
air.setPm25(65);
airMapper.updateById(air);
}
因為像new Date()這種在代碼中出現,顯得很low而且消耗資源,我們可以使用注解的方式:
自動填充
創建時間,修改時間這些個操作一般都是自動化完成的不希望手動更新
阿里巴巴研發手冊: 所有的數據庫表:gmt_create,gmt_modified(格林尼治時間)
方式一:數據庫方式(工作中一般是不允許修改數據庫的,因為牽扯的問題很多很復雜特別容易出bug還找不出來)
- 在表中的這兩個表,就是創建和修改時間
- 打鈎自動更新當前時間
如果還有自己手寫日期的小伙伴,以后你就不用一個一個添加了
代碼級別
- 刪除數據庫默認值
- 實體類的字段屬性上需要增加注釋
@TableField
源碼如下,可以看到fill的方法就是填充方法
public class Air {
@TableId(type = IdType.ASSIGN_ID)
private Long id;
private long districtId;
@TableField(fill = FieldFill.INSERT) //插入的時候更新插入時間
private Date monitorTime;
private long pm10;
private long pm25;
private String monitoringStation;
@TableField(fill = FieldFill.INSERT_UPDATE) //更新和插入的時候都更新時間
private Date lastModifyTime;
}
當然填充策略可以重寫,進行自定義填充策略
首先創建一個MyMetaObjectHandler類(名字隨便)
@Slf4j //抓取日志
@Component //SpringBoot的注解 ,一定不要忘了吧處理器加到IOC容器中
public class MyMetaObjectHandler implements MetaObjectHandler {
@Override
public void insertFill(MetaObject metaObject) {
log.info("start insert fill");
//源碼: setFieldValByName(String fieldName(字段名), Object fieldVal(字段值), MetaObject metaObjec(對象))
this.setFieldValByName("monitor_time",new Date(),metaObject);
this.setFieldValByName("last_modify_time",new Date(),metaObject);
}
@Override
public void updateFill(MetaObject metaObject) {
log.info("Start update fill....");
this.setFieldValByName("last_modify_time",new Date(),metaObject);
}
}
測試
增加:
更新
可以看到時間已經自動更新為當前的時間了