1峡竣、BaseMapper
MyBatis-Plus中的基本CRUD在內(nèi)置的BaseMapper中都已得到了實現(xiàn)租谈,我們可以直接使用偷厦,接口如下:
public interface BaseMapper<T> extends Mapper<T> {
//插入一條記錄
int insert(T entity);
//根據(jù) ID 刪除
int deleteById(Serializable id);
//根據(jù)實體(ID)刪除
int deleteById(T entity);
//根據(jù) columnMap 條件由捎,刪除記錄
int deleteByMap(@Param("cm") Map<String, Object> columnMap);
//根據(jù) entity 條件兔综,刪除記錄
//queryWrapper 實體對象封裝操作類(可以為 null,里面的 entity 用于生成 where 語句)
int delete(@Param("ew") Wrapper<T> queryWrapper);
//刪除(根據(jù)ID 批量刪除)
//idList 主鍵ID列表(不能為 null 以及 empty)
int deleteBatchIds(@Param("coll") Collection<?> idList);
//根據(jù) ID 修改
int updateById(@Param("et") T entity);
//根據(jù) whereEntity 條件,更新記錄
//entity 實體對象 (set 條件值,可以為 null)
//updateWrapper 實體對象封裝操作類(可以為 null,里面的 entity 用于生成 where 語句)
int update(@Param("et") T entity, @Param("ew") Wrapper<T> updateWrapper);
//根據(jù) ID 查詢
T selectById(Serializable id);
//查詢(根據(jù)ID 批量查詢)
//idList 主鍵ID列表(不能為 null 以及 empty)
List<T> selectBatchIds(@Param("coll") Collection<? extends Serializable> idList);
//查詢(根據(jù) columnMap 條件)
List<T> selectByMap(@Param("cm") Map<String, Object> columnMap);
//根據(jù) entity 條件,查詢一條記錄软驰,多條數(shù)據(jù)會報異常
//queryWrapper 實體對象封裝操作類(可以為 null)
default T selectOne(@Param("ew") Wrapper<T> queryWrapper) {
List<T> ts = this.selectList(queryWrapper);
if (CollectionUtils.isNotEmpty(ts)) {
if (ts.size() != 1) {
throw ExceptionUtils.mpe("One record is expected, but the query result is multiple records", new Object[0]);
} else {
return ts.get(0);
}
} else {
return null;
}
}
//根據(jù) entity 條件涧窒,查詢記錄是否存在
default boolean exists(Wrapper<T> queryWrapper) {
Long count = this.selectCount(queryWrapper);
return null != count && count > 0L;
}
//根據(jù) Wrapper 條件,查詢總記錄數(shù)
Long selectCount(@Param("ew") Wrapper<T> queryWrapper);
//根據(jù) entity 條件锭亏,查詢?nèi)坑涗? List<T> selectList(@Param("ew") Wrapper<T> queryWrapper);
//根據(jù) Wrapper 條件纠吴,查詢?nèi)坑涗? List<Map<String, Object>> selectMaps(@Param("ew") Wrapper<T> queryWrapper);
//根據(jù) Wrapper 條件,查詢?nèi)坑涗浕哿觯环祷氐谝粋€字段的值(這里測試時第一個字段為id戴已,即返回id值)
List<Object> selectObjs(@Param("ew") Wrapper<T> queryWrapper);
//根據(jù) entity 條件,查詢?nèi)坑涗洠ú⒎摚? //page 分頁查詢條件(可以為 RowBounds.DEFAULT)
//queryWrapper 實體對象封裝操作類(可以為 null)
<P extends IPage<T>> P selectPage(P page, @Param("ew") Wrapper<T> queryWrapper);
//根據(jù) Wrapper 條件锅减,查詢?nèi)坑涗洠ú⒎摚? //page 分頁查詢條件
//queryWrapper 實體對象封裝操作類
<P extends IPage<Map<String, Object>>> P selectMapsPage(P page, @Param("ew") Wrapper<T> queryWrapper);
}
2糖儡、插入
@Test
public void testInsert(){
User user = new User(null, "張三", 23, "zhangsan@atguigu.com");
int result = userMapper.insert(user);
System.out.println("受影響行數(shù):"+result);
//1549240899871428610
System.out.println("id自動獲取:"+user.getId());
}
最終執(zhí)行的結(jié)果怔匣,所獲取的id為1549240899871428610
這是因為MyBatis-Plus在實現(xiàn)插入數(shù)據(jù)時握联,會默認基于雪花算法的策略生成id
3、刪除
(1)通過id刪除記錄
@Test public void testDeleteById(){
//通過id刪除用戶信息
int result = userMapper.deleteById(1549240899871428610L);
System.out.println("受影響行數(shù):"+result);
}
(2)通過id批量刪除記錄
@Test
public void testDeleteBatchIds(){
//通過多個id批量刪除
List<Long> idList = Arrays.asList(1L, 2L, 3L);
int result = userMapper.deleteBatchIds(idList);
System.out.println("受影響行數(shù):"+result);
}
(3)通過map條件刪除記錄
@Test
public void testDeleteByMap(){
//根據(jù)map集合中所設(shè)置的條件刪除記錄
Map<String, Object> map = new HashMap<>();
map.put("age", 23);
map.put("name", "張三");
int result = userMapper.deleteByMap(map);
System.out.println("受影響行數(shù):"+result);
}
3每瞒、修改
@Test
public void testUpdateById(){
User user = new User(4L, "admin", 22, null);
int result = userMapper.updateById(user);
System.out.println("受影響行數(shù):"+result);
}
4金闽、查詢
(1)根據(jù)id查詢用戶信息
@Test
public void testSelectById() {
//根據(jù)id查詢用戶信息
User user = userMapper.selectById(4L);
System.out.println(user);
}
(2)根據(jù)多個id查詢多個用戶信息
@Test
public void testSelectBatchIds() {
//根據(jù)多個id查詢多個用戶信息
List<Long> idList = Arrays.asList(4L, 5L);
List<User> list = userMapper.selectBatchIds(idList);
list.forEach(System.out::println);
}
(3)通過map條件查詢用戶信息
@Test
public void testSelectByMap() {
//通過map條件查詢用戶信息
Map<String, Object> map = new HashMap<>();
map.put("age", 22);
map.put("name", "admin");
List<User> list = userMapper.selectByMap(map);
list.forEach(System.out::println);
}
(4)查詢所有數(shù)據(jù)
@Test
public void testSelectList (){
//查詢所有用戶信息
List<User> list = userMapper.selectList(null);
list.forEach(System.out::println);
}
通過觀察BaseMapper中的方法,大多方法中都有Wrapper類型的形參独泞,此為條件構(gòu)造器呐矾,可針對于SQL語句設(shè)置不同的條件,若沒有條件懦砂,則可以為該形參賦值null蜒犯,即查詢(刪除/修改)所有數(shù)據(jù)
5、通用Service
通用 Service CRUD 封裝IService接口荞膘,進一步封裝 CRUD 采用 get 查詢單行罚随,remove 刪除,list 查詢集合羽资,page 分頁淘菩,前綴命名方式區(qū)分 Mapper 層避免混淆;
泛型 T 為任意實體對象屠升;
建議如果存在自定義通用 Service 方法的可能潮改,請創(chuàng)建自己的 IBaseService 繼承
Mybatis-Plus 提供的基類
(1)IService
MyBatis-Plus中有一個接口 IService和其實現(xiàn)類 ServiceImpl,封裝了常見的業(yè)務(wù)層邏輯
(2)創(chuàng)建Service接口
/**
* UserService繼承IService模板提供的基礎(chǔ)功能
*/
public interface UserService extends IService<User> {
}
(3)創(chuàng)建實現(xiàn)類
/**
* ServiceImpl實現(xiàn)了IService腹暖,提供了IService中基礎(chǔ)功能的實現(xiàn)
* 若ServiceImpl無法滿足業(yè)務(wù)需求汇在,則可以使用自定的UserService定義方法,并在實現(xiàn)類中實現(xiàn)
*/
@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService {
}
6脏答、測試IService接口中的方法
(1)測試查詢記錄數(shù)
@Test
public void testGetCount(){
long count = userService.count();
System.out.println("總記錄數(shù):" + count);
}
(2)測試批量插入
@Test
public void testSaveBatch(){
// SQL長度有限制糕殉,海量數(shù)據(jù)插入單條SQL無法實行亩鬼,
// 因此MP將批量插入放在了通用Service中實現(xiàn),而不是通用Mapper
ArrayList<User> users = new ArrayList<>();
for (int i = 0; i < 5; i++) {
User user = new User();
user.setName("ybc" + i);
user.setAge(20 + i);
users.add(user);
}
userService.saveBatch(users);
}