mybatisplusiservice是一個為了簡化開發的Mybatis-plus的擴展服務,它提供了很多常用的CRUD方法,使得開發者不必寫重複的代碼,而且還可以方便地進行分頁操作。本文將從以下幾個方面逐一深入探究mybatisplusiservice。
一、mybatisplusiservice的基本使用
使用mybatisplusiservice非常簡單,只需要在Service層中繼承IService接口即可。例如:
@Service public class UserServiceImpl extends ServiceImpl implements IUserService { }
這裡UserService繼承ServiceImpl實現了IUserService接口,並指定了實體類User和Mapper類UserMapper。此時,UserService類即繼承了mybatisplusiservice的所有方法。
我們來看一個簡單的示例代碼:
@Service public class UserServiceImpl extends ServiceImpl implements IUserService {
@Autowired UserMapper userMapper;
public List selectAll() {
return userMapper.selectList(null);
}
}
可以發現,selectList是mybatisplusiservice中提供的方法之一,它可以非常方便地實現基礎查詢操作,而且不用寫SQL,只需要傳入null即可返回所有實體。當然,mybatisplusiservice也提供諸如selectById、 insert等其他基礎操作方法,使用方法與此類似。
二、mybatisplusiservice的分頁操作
分頁是一個常見的操作需求,mybatisplusiservice也為我們提供了很方便的分頁API。以Service層的查詢方法為例:
public IPage selectPage(Page page) {
return userMapper.selectPage(page, null);
}
在這個方法中,我們使用了mybatisplusiservice提供的selectPage分頁方法,並傳入了分頁查詢的參數Page實例。Page實例中包含了分頁參數和排序參數,直接傳入mapper即可實現分頁查詢。
而在調用分頁查詢方法時,我們只需要根據需求設置Page實例中的參數即可。例如:
Page page = new Page();
page.setCurrent(1); //當前頁
page.setSize(20); //每頁大小
page.setDesc("create_time"); //按照創建時間降序排列
IPage userIPage = userService.selectPage(page);
List users = userIPage.getRecords();
這樣,我們就可以得到第一頁20條數據,並按照創建時間降序排列。
三、mybatisplusiservice的條件構造器
條件構造器是mybatisplusiservice中非常重要的一部分。它可以幫助我們根據實體類字段直接構造查詢條件,避免手寫SQL,從而提高開發效率。
以查詢指定時間區間內創建的用戶為例:
public List selectByCreateTimeBetween(LocalDateTime start, LocalDateTime end) {
LambdaQueryWrapper wrapper = new LambdaQueryWrapper();
wrapper.between(User::getCreateTime, start, end);
return userMapper.selectList(wrapper);
}
在這個方法中,我們使用了LambdaQueryWrapper構造器來構造查詢條件。between方法的第一個參數是User實體類中的屬性,第二個和第三個參數分別是時間區間的開始和結束時間。而selectList方法則是mybatisplusiservice提供的查詢方法,它接收一個前面構造的LambdaQueryWrapper構造器作為參數。
其中,LambdaQueryWrapper構造器提供了大量的操作方法,例如eq等值查詢、ge、gt等比較查詢、in、notIn、like等集合查詢以及自定義SQL查詢等等,十分方便實用。
四、mybatisplusiservice的自動填充機制
自動填充機制是mybatisplusiservice中的一項高級功能。使用這個機制,我們可以自動填充數據庫中的某些字段,例如create_time、update_time,而不需要手動設置。
首先,在實體類中使用mybatisplusiservice的註解@TableField標註需要自動填充的字段,例如:
@Data @TableName("tbl_user") public class User {
@TableId(type = IdType.AUTO) private Long id;
private String name;
private Integer age;
private String email;
@TableField(fill = FieldFill.INSERT) private LocalDateTime createTime;
@TableField(fill = FieldFill.UPDATE) private LocalDateTime updateTime;
}
在這個示例代碼中,我們使用@TableField註解標識了createTime和updateTime兩個字段需要自動填充。填充方式分別是INSERT和UPDATE,表示創建時自動填充和更新時自動填充。
在編寫Mapper時,我們只需要使用mybatisplusiservice提供的BaseMapper接口,並在實體類中設置了@TableField註解之後,就可以對以上標有@TableField註解的字段進行自動填充。例如:
@Component public interface UserMapper extends BaseMapper { }
這樣,我們就可以在數據庫中自動填充createTime和updateTime兩個字段了。
五、小結
mybatisplusiservice提供了多項方便實用的開發功能,包括基礎的CRUD操作、分頁查詢、條件構造器和自動填充機制等。在實際開發中,使用mybatisplusiservice可以大幅提升開發效率,減少重複的代碼編寫,同時提供了很方便的擴展接口。
原創文章,作者:ZZNYR,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/369229.html