三 mybatis-plus實(shí)現(xiàn)基本CRUD

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);
    }
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容