1、BaseMapper
MyBatis-Plus中的基本CRUD在內(nèi)置的BaseMapper中都已得到了實(shí)現(xiàn),我們可以直接使用,接口如下:
public interface BaseMapper<T> extends Mapper<T> {
//插入一條記錄
int insert(T entity);
//根據(jù) ID 刪除
int deleteById(Serializable id);
//根據(jù)實(shí)體(ID)刪除
int deleteById(T entity);
//根據(jù) columnMap 條件,刪除記錄
int deleteByMap(@Param("cm") Map<String, Object> columnMap);
//根據(jù) entity 條件,刪除記錄
//queryWrapper 實(shí)體對(duì)象封裝操作類(可以為 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 實(shí)體對(duì)象 (set 條件值,可以為 null)
//updateWrapper 實(shí)體對(duì)象封裝操作類(可以為 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ù)會(huì)報(bào)異常
//queryWrapper 實(shí)體對(duì)象封裝操作類(可以為 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)坑涗洠环祷氐谝粋€(gè)字段的值(這里測(cè)試時(shí)第一個(gè)字段為id,即返回id值)
List<Object> selectObjs(@Param("ew") Wrapper<T> queryWrapper);
//根據(jù) entity 條件,查詢?nèi)坑涗洠ú⒎摚? //page 分頁查詢條件(可以為 RowBounds.DEFAULT)
//queryWrapper 實(shí)體對(duì)象封裝操作類(可以為 null)
<P extends IPage<T>> P selectPage(P page, @Param("ew") Wrapper<T> queryWrapper);
//根據(jù) Wrapper 條件,查詢?nèi)坑涗洠ú⒎摚? //page 分頁查詢條件
//queryWrapper 實(shí)體對(duì)象封裝操作類
<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自動(dòng)獲取:"+user.getId());
}
最終執(zhí)行的結(jié)果,所獲取的id為1549240899871428610
這是因?yàn)镸yBatis-Plus在實(shí)現(xiàn)插入數(shù)據(jù)時(shí),會(huì)默認(rèn)基于雪花算法的策略生成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(){
//通過多個(gè)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ù)多個(gè)id查詢多個(gè)用戶信息
@Test
public void testSelectBatchIds() {
//根據(jù)多個(gè)id查詢多個(gè)用戶信息
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)造器,可針對(duì)于SQL語句設(shè)置不同的條件,若沒有條件,則可以為該形參賦值null,即查詢(刪除/修改)所有數(shù)據(jù)
5、通用Service
通用 Service CRUD 封裝IService接口,進(jìn)一步封裝 CRUD 采用 get 查詢單行,remove 刪除,list 查詢集合,page 分頁,前綴命名方式區(qū)分 Mapper 層避免混淆;
泛型 T 為任意實(shí)體對(duì)象;
建議如果存在自定義通用 Service 方法的可能,請(qǐng)創(chuàng)建自己的 IBaseService 繼承
Mybatis-Plus 提供的基類
(1)IService
MyBatis-Plus中有一個(gè)接口 IService和其實(shí)現(xiàn)類 ServiceImpl,封裝了常見的業(yè)務(wù)層邏輯
(2)創(chuàng)建Service接口
/**
* UserService繼承IService模板提供的基礎(chǔ)功能
*/
public interface UserService extends IService<User> {
}
(3)創(chuàng)建實(shí)現(xiàn)類
/**
* ServiceImpl實(shí)現(xiàn)了IService,提供了IService中基礎(chǔ)功能的實(shí)現(xiàn)
* 若ServiceImpl無法滿足業(yè)務(wù)需求,則可以使用自定的UserService定義方法,并在實(shí)現(xiàn)類中實(shí)現(xiàn)
*/
@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService {
}
6、測(cè)試IService接口中的方法
(1)測(cè)試查詢記錄數(shù)
@Test
public void testGetCount(){
long count = userService.count();
System.out.println("總記錄數(shù):" + count);
}
(2)測(cè)試批量插入
@Test
public void testSaveBatch(){
// SQL長(zhǎng)度有限制,海量數(shù)據(jù)插入單條SQL無法實(shí)行,
// 因此MP將批量插入放在了通用Service中實(shí)現(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);
}