MyBatisPlus的IService接口實(shí)現(xiàn)
MyBatis Plus(簡稱MP)是一個(gè)MyBatis的增強(qiáng)工具,旨在簡化開發(fā)、提高效率。它提供了許多便捷的功能,其中之一就是IService
接口。IService
接口是MyBatis Plus提供的一個(gè)服務(wù)層接口,封裝了常用的CRUD操作,使得開發(fā)者可以更加便捷地進(jìn)行數(shù)據(jù)庫操作。本文將詳細(xì)講解IService
接口,包括其基本概念、常用方法以及實(shí)際應(yīng)用場景。
1. 基本概念
IService
接口是MyBatis Plus提供的一個(gè)服務(wù)層接口,定義了一系列常用的CRUD操作方法。通過實(shí)現(xiàn)IService
接口,可以快速構(gòu)建服務(wù)層,簡化開發(fā)流程。
1.1 接口定義
IService
接口定義如下:
public interface IService<T> { // 插入一條記錄(選擇字段,策略插入) boolean save(T entity); // 插入(批量) boolean saveBatch(Collection<T> entityList); // 插入(批量) boolean saveBatch(Collection<T> entityList, int batchSize); // 根據(jù) ID 刪除 boolean removeById(Serializable id); // 根據(jù)實(shí)體(ID)刪除 boolean removeById(T entity); // 根據(jù) columnMap 條件,刪除記錄 boolean removeByMap(Map<String, Object> columnMap); // 根據(jù) entity 條件,刪除記錄 boolean remove(Wrapper<T> queryWrapper); // 刪除(根據(jù)ID 批量刪除) boolean removeByIds(Collection<? extends Serializable> idList); // 根據(jù) ID 選擇修改 boolean updateById(T entity); // 根據(jù) whereEntity 條件,更新記錄 boolean update(T entity, Wrapper<T> updateWrapper); // 根據(jù) ID 查詢 T getById(Serializable id); // 查詢(根據(jù)ID 批量查詢) List<T> listByIds(Collection<? extends Serializable> idList); // 查詢(根據(jù) columnMap 條件) List<T> listByMap(Map<String, Object> columnMap); // 根據(jù) entity 條件,查詢一條記錄 T getOne(Wrapper<T> queryWrapper); // 根據(jù) Wrapper 條件,查詢?nèi)坑涗? List<T> list(Wrapper<T> queryWrapper); // 查詢所有 List<T> list(); // 查詢總記錄數(shù) int count(); // 查詢總記錄數(shù) int count(Wrapper<T> queryWrapper); // 查詢所有列表 List<Map<String, Object>> listMaps(Wrapper<T> queryWrapper); // 查詢所有列表 List<Map<String, Object>> listMaps(); // 查詢?nèi)坑涗? List<Object> listObjs(); // 查詢?nèi)坑涗? <V> List<V> listObjs(Function<? super Object, V> mapper); // 根據(jù) Wrapper 條件,查詢?nèi)坑涗? List<Object> listObjs(Wrapper<T> queryWrapper); // 根據(jù) Wrapper 條件,查詢?nèi)坑涗? <V> List<V> listObjs(Wrapper<T> queryWrapper, Function<? super Object, V> mapper); // 無條件分頁查詢 IPage<T> page(IPage<T> page); // 條件分頁查詢 IPage<T> page(IPage<T> page, Wrapper<T> queryWrapper); // 無條件分頁查詢 IPage<Map<String, Object>> pageMaps(IPage<T> page); // 條件分頁查詢 IPage<Map<String, Object>> pageMaps(IPage<T> page, Wrapper<T> queryWrapper); }
1.2 實(shí)現(xiàn)類
為了使用IService
接口,通常需要創(chuàng)建一個(gè)實(shí)現(xiàn)類,繼承ServiceImpl
類,并實(shí)現(xiàn)IService
接口。ServiceImpl
類是MyBatis Plus提供的一個(gè)默認(rèn)實(shí)現(xiàn)類,封裝了常用的CRUD操作。
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements IService<User> { // 自定義方法 }
在上述代碼中,UserServiceImpl
繼承了ServiceImpl
類,并實(shí)現(xiàn)了IService<User>
接口。ServiceImpl
類的構(gòu)造函數(shù)需要傳入Mapper接口和實(shí)體類。
2. 常用方法
2.1 插入操作
- save:插入一條記錄(選擇字段,策略插入)
- saveBatch:插入(批量)
User user = new User(); user.setName("John"); user.setAge(25); userService.save(user); List<User> userList = new ArrayList<>(); userList.add(new User("John", 25, "john@example.com")); userList.add(new User("Jane", 30, "jane@example.com")); userService.saveBatch(userList);
2.2 刪除操作
- removeById:根據(jù)ID刪除
- removeByMap:根據(jù)columnMap條件刪除
- remove:根據(jù)entity條件刪除
- removeByIds:根據(jù)ID批量刪除
userService.removeById(1); Map<String, Object> columnMap = new HashMap<>(); columnMap.put("age", 25); userService.removeByMap(columnMap); QueryWrapper<User> queryWrapper = new QueryWrapper<>(); queryWrapper.eq("age", 25); userService.remove(queryWrapper); List<Integer> idList = Arrays.asList(1, 2, 3); userService.removeByIds(idList);
2.3 更新操作
- updateById:根據(jù)ID更新
- update:根據(jù)whereEntity條件更新
User user = new User(); user.setId(1); user.setName("John Doe"); user.setAge(26); userService.updateById(user); User user = new User(); user.setStatus(1); QueryWrapper<User> updateWrapper = new QueryWrapper<>(); updateWrapper.eq("age", 25); userService.update(user, updateWrapper);
2.4 查詢操作
- getById:根據(jù)ID查詢
- listByIds:根據(jù)ID批量查詢
- listByMap:根據(jù)columnMap條件查詢
- getOne:根據(jù)entity條件查詢一條記錄
- list:根據(jù)Wrapper條件查詢?nèi)坑涗?/li>
- list:查詢所有
- count:查詢總記錄數(shù)
- page:無條件分頁查詢
- page:條件分頁查詢
User user = userService.getById(1); List<Integer> idList = Arrays.asList(1, 2, 3); List<User> userList = userService.listByIds(idList); Map<String, Object> columnMap = new HashMap<>(); columnMap.put("age", 25); List<User> userList = userService.listByMap(columnMap); QueryWrapper<User> queryWrapper = new QueryWrapper<>(); queryWrapper.eq("age", 25); User user = userService.getOne(queryWrapper); QueryWrapper<User> queryWrapper = new QueryWrapper<>(); queryWrapper.eq("age", 25); List<User> userList = userService.list(queryWrapper); List<User> userList = userService.list(); int count = userService.count(); Page<User> page = new Page<>(1, 10); IPage<User> userPage = userService.page(page); Page<User> page = new Page<>(1, 10); QueryWrapper<User> queryWrapper = new QueryWrapper<>(); queryWrapper.eq("age", 25); IPage<User> userPage = userService.page(page, queryWrapper);
3. 實(shí)際應(yīng)用場景
3.1 用戶管理
假設(shè)我們有一個(gè)用戶管理系統(tǒng),需要對用戶進(jìn)行增刪改查操作。通過IService
接口,可以輕松實(shí)現(xiàn)這些功能。
@Service public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements IService<User> { // 自定義方法 public User getUserByName(String name) { QueryWrapper<User> queryWrapper = new QueryWrapper<>(); queryWrapper.eq("name", name); return getOne(queryWrapper); } }
在上述代碼中,我們定義了一個(gè)自定義方法getUserByName
,根據(jù)用戶名查詢用戶信息。
3.2 訂單管理
假設(shè)我們有一個(gè)訂單管理系統(tǒng),需要對訂單進(jìn)行增刪改查操作。通過IService
接口,可以輕松實(shí)現(xiàn)這些功能。
@Service public class OrderServiceImpl extends ServiceImpl<OrderMapper, Order> implements IService<Order> { // 自定義方法 public List<Order> getOrdersByUserId(int userId) { QueryWrapper<Order> queryWrapper = new QueryWrapper<>(); queryWrapper.eq("user_id", userId); return list(queryWrapper); } }
在上述代碼中,我們定義了一個(gè)自定義方法getOrdersByUserId
,根據(jù)用戶ID查詢訂單信息。
4. 總結(jié)
MyBatis Plus的IService
接口提供了一系列常用的CRUD操作方法,使得開發(fā)者可以更加便捷地進(jìn)行數(shù)據(jù)庫操作。通過實(shí)現(xiàn)IService
接口,并繼承ServiceImpl
類,可以快速構(gòu)建服務(wù)層,簡化開發(fā)流程。在實(shí)際應(yīng)用中,結(jié)合自定義方法,可以進(jìn)一步提高開發(fā)效率和代碼可維護(hù)性。
到此這篇關(guān)于MyBatisPlus的IService接口實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)MyBatisPlus IService接口內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringBoot整合Mybatis Generator自動生成代碼
SpringBoot 整合 Mybatis Generator自動生成dao、entity、mapper.xml實(shí)現(xiàn)單表增刪改查。文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-08-08jxl操作excel寫入數(shù)據(jù)不覆蓋原有數(shù)據(jù)示例
網(wǎng)上很多例子,都是用Jxl讀或者寫excel,本文實(shí)現(xiàn)的功能就是將數(shù)據(jù)源in.xls的第幾行第幾列數(shù)據(jù)寫入到out.xls的第幾行第幾列,不覆蓋out.xls其他原有的數(shù)據(jù)。2014-03-03SpringBoot任意版本集成Swagger各種版本的操作指南
在學(xué)習(xí)Swagger生成API文檔的時(shí)候經(jīng)常會遇到問題,而目前市面上大部分技術(shù)分享者的SpringBoot版本并沒和我們的同步,導(dǎo)致一些一模一樣的代碼,在我們的項(xiàng)目上卻無法使用,這是一個(gè)經(jīng)常性的問題,本文章就旨在和大家搞定SpringBoot任意版本集成Swagger各種版本2024-07-07使用Mybatis-plus策略自動更新數(shù)據(jù)庫時(shí)間失敗問題解決
這篇文章主要介紹了使用Mybatis-plus策略自動更新數(shù)據(jù)庫時(shí)間失敗問題解決,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-10-10