```
/**
* @author 張躍帥
* @Description: mybatis-plus自定義mapper增強-接口
* @date 2020/08/12
*/
public interface MyBaseMapper<T> extends BaseMapper<T> {
/**
* 自定義-分頁查詢
*/
default PageResult<T> getPage(Object searchObj, Wrapper<T> queryWrapper) {
// 設置分頁和排序字段及排序方式
Page<T> mpPage = PageFactory.getPage(searchObj);
// 查詢全部記錄(并翻頁)
Page<T> finalMpPage = this.selectPage(mpPage, queryWrapper);
// 分頁結果
PageResult<T> pageResult = PageResultFactory.pageResult(finalMpPage);
// 返回
return pageResult;
}
/**
* 改造selectPage-分頁查詢
* 備注:實現自定義的分頁工廠
*/
default Page<T> selectPage(Object searchObj, Wrapper<T> queryWrapper) {
// 設置分頁和排序字段及排序方式
Page<T> mpPage = PageFactory.getPage(searchObj);
// 查詢全部記錄(并翻頁)
Page<T> finalMpPage = this.selectPage(mpPage, queryWrapper);
// 返回
return finalMpPage;
}
/**
* 批量插入-適合大量數據插入
*
* @param entityList 實體List
*/
default boolean insertBatch(Collection<T> entityList) {
return Db.saveBatch(entityList);
}
/**
* 批量插入-適合大量數據插入
*
* @param entityList 實體List
* @param size 插入數量-默認為 1000
*/
default boolean insertBatch(Collection<T> entityList, int size) {
return Db.saveBatch(entityList, size);
}
/**
* 根據ID批量更新-適合大量數據更新
*
* @param entityList 實體List
*/
default boolean updateBatch(Collection<T> entityList) {
return Db.updateBatchById(entityList);
}
/**
* 根據ID批量更新-適合大量數據更新
*
* @param entityList 實體List
* @param size 更新數量-默認為 1000
*/
default boolean updateBatch(Collection<T> entityList, int size) {
return Db.updateBatchById(entityList, size);
}
/**
* 批量修改插入-根據實體的主鍵是否為空,更新還是修改
* 默認為 1000
*
* @param entityList 實體List
*/
default boolean saveOrUpdateBatch(Collection<T> entityList) {
return Db.saveOrUpdateBatch(entityList);
}
}
- Jump簡介
- 技術架構
- 代碼規范
- 規范導讀
- JAVA規范
- 數據庫表設計規范
- 集成項目
- JDK1.8-pom.xml
- JDK21-pom.xml
- 項目結構
- 業務模塊-方法名稱規范
- 跨域配置
- License授權配置
- 公共字段自動填充
- 全局異常處理器
- PageOffice配置
- Beetl模板引擎配置
- application.properties
- application-prod.yml
- banner.txt
- logback-spring.xml
- jump-core (核心組件)
- Maven依賴
- 通用枚舉
- 公共數據狀態 - 枚舉
- 公共邏輯刪除 - 枚舉
- 公共操作編碼類型 - 枚舉
- 公共tree父節點 - 枚舉
- 公共是或否 - 枚舉
- 工具Util
- AopTargetUtil
- DownloadUtil
- GenerateNumUtil
- HttpServletUtil
- IpUtil
- JoinPointUtil
- MacUtil
- NetworkUtil
- ParamToUtil
- ResponseUtil
- TimeZoneDateUtil
- UaUtil
- 統一返回
- 結果對象
- 如何使用
- jump-cahche (緩存組件)
- Maven依賴
- Redis配置
- 緩存常量
- 工具Util
- RedisCacheUtil
- jump-idempotent (幕等組件)
- Maven依賴
- Context上下文
- 操作器
- 接口
- 如何實現
- AOP參數
- AOP使用方法
- jump-lock (分布式鎖組件)
- Maven依賴
- 枚舉
- AOP參數
- AOP使用方法
- 工具Util
- RedissonLockUtil
- Util使用方法
- jump-mybatis (mybatis組件)
- Maven依賴
- 基礎Entity
- 枚舉
- 查詢類型 - 枚舉
- 條件查詢
- search
- service
- 分頁結果集
- Mapper
- MyMapper
- 使用方法
- DDL操作
- DML操作
- 工具Util
- EntityUtil
- PageUtil
- TableUtil
- jump-dynamic-datasource (多數據源組件)
- Maven依賴
- Context上下文
- 操作器
- 接口
- 如何實現
- 工具Util
- DatasourceUtil
- 如何使用
- jump-satoken (satoken組件)
- Maven依賴
- Context上下文
- 操作器
- 接口
- 如何實現
- Satoken配置信息
- SatokenUser信息
- Redis緩存操作
- SatokenRedisCache
- SatokenUserRedisCache
- 放行白名單
- jump-oss (OSS組件)
- Maven依賴
- 工具Util
- OssFileUtil
- OssPlatformUtil
- 如何使用
- jump-xss (XSS組件)
- Maven依賴
- 白名單放行
- jump-email (郵件組件)
- Maven依賴
- Email客戶端信息
- Email發送參數
- 工具Util
- jump-websocket (WebSocket組件)
- Maven依賴
- 消息對象
- 工具Util
- 如何使用
- jump-weixin (微信組件)
- Maven依賴
- jump-system (系統管理組件)
- Maven依賴
- AOP
- 系統操作日志AOP
- 系統數據日志AOP
- 系統操作權限AOP
- 字典轉文本AOP
- Redis緩存操作
- SystemConfigRedisCache
- 工具Util
- LoginUserUtil
- SystemAreaUtil
- SystemHomeUtil
- SystemMenuUtil
- SystemOrgAdminUtil
- SystemOrgTypeUtil
- SystemRoleUtil
- SystemUserLoginAreaUtil
- SystemUserUtil
- jump-timer(定時器組件)
- Maven依賴
- 枚舉
- Api接口
- 工具Util
- ActionClassUtil
- TimerTaskUtil
- 如何使用
- jump-ueditor (富文本組件)
- Maven依賴
- 如何使用
- 配置 ueditor.config.js
- 后端 application.properties
- 前端 vue3
- vue-codemirror (代碼編譯器)
- npm依賴
- PageOffice整合
- Maven依賴
- License授權配置
- 枚舉
- 文件來源 - 枚舉
- 預覽文件類型 - 枚舉
- 文件預覽參數
- 下載文件
- 預覽文件
- 工具Util