網(wǎng)站首頁(yè) 編程語(yǔ)言 正文
一、Service層
【添加數(shù)據(jù):(增)】
default boolean save(T entity); // 調(diào)用 BaseMapper 的 insert 方法,用于添加一條數(shù)據(jù)。
boolean saveBatch(Collection<T> entityList, int batchSize); // 批量插入數(shù)據(jù)
注:
entityList 表示實(shí)體對(duì)象集合
batchSize 表示一次批量插入的數(shù)據(jù)量,默認(rèn)為 1000
【添加或修改數(shù)據(jù):(增或改)】
boolean saveOrUpdate(T entity); // id 若存在,則修改, id 不存在則新增數(shù)據(jù)
default boolean saveOrUpdate(T entity, Wrapper<T> updateWrapper); // 先根據(jù)條件嘗試更新,然后再執(zhí)行 saveOrUpdate 操作
boolean saveOrUpdateBatch(Collection<T> entityList, int batchSize); // 批量插入并修改數(shù)據(jù)
【刪除數(shù)據(jù):(刪)】
default boolean removeById(Serializable id); // 調(diào)用 BaseMapper 的 deleteById 方法,根據(jù) id 刪除數(shù)據(jù)。
default boolean removeByMap(Map<String, Object> columnMap); // 調(diào)用 BaseMapper 的 deleteByMap 方法,根據(jù) map 定義字段的條件刪除
default boolean remove(Wrapper<T> queryWrapper); // 調(diào)用 BaseMapper 的 delete 方法,根據(jù)實(shí)體類定義的 條件刪除對(duì)象。
default boolean removeByIds(Collection<? extends Serializable> idList); // 用 BaseMapper 的 deleteBatchIds 方法, 進(jìn)行批量刪除。
【修改數(shù)據(jù):(改)】
default boolean updateById(T entity); // 調(diào)用 BaseMapper 的 updateById 方法,根據(jù) ID 選擇修改。
default boolean update(T entity, Wrapper<T> updateWrapper); // 調(diào)用 BaseMapper 的 update 方法,根據(jù) updateWrapper 條件修改實(shí)體對(duì)象。
boolean updateBatchById(Collection<T> entityList, int batchSize); // 批量更新數(shù)據(jù)
【查找數(shù)據(jù):(查)】
default T getById(Serializable id); // 調(diào)用 BaseMapper 的 selectById 方法,根據(jù) 主鍵 ID 返回?cái)?shù)據(jù)。
default List<T> listByIds(Collection<? extends Serializable> idList); // 調(diào)用 BaseMapper 的 selectBatchIds 方法,批量查詢數(shù)據(jù)。
default List<T> listByMap(Map<String, Object> columnMap); // 調(diào)用 BaseMapper 的 selectByMap 方法,根據(jù)表字段條件查詢
default T getOne(Wrapper<T> queryWrapper); // 返回一條記錄(實(shí)體類保存)。
Map<String, Object> getMap(Wrapper<T> queryWrapper); // 返回一條記錄(map 保存)。
default int count(Wrapper<T> queryWrapper); // 根據(jù)條件返回 記錄數(shù)。
default List<T> list(); // 返回所有數(shù)據(jù)。
default List<T> list(Wrapper<T> queryWrapper); // 調(diào)用 BaseMapper 的 selectList 方法,查詢所有記錄(返回 entity 集合)。
default List<Map<String, Object>> listMaps(Wrapper<T> queryWrapper); // 調(diào)用 BaseMapper 的 selectMaps 方法,查詢所有記錄(返回 map 集合)。
default List<Object> listObjs(); // 返回全部記錄,但只返回第一個(gè)字段的值。
default <E extends IPage<T>> E page(E page, Wrapper<T> queryWrapper); // 調(diào)用 BaseMapper 的 selectPage 方法,分頁(yè)查詢
default <E extends IPage<Map<String, Object>>> E pageMaps(E page, Wrapper<T> queryWrapper); // 調(diào)用 BaseMapper 的 selectMapsPage 方法,分頁(yè)查詢
注:
get 用于返回一條記錄。
list 用于返回多條記錄。
count 用于返回記錄總數(shù)。
page 用于分頁(yè)查詢。
【鏈?zhǔn)秸{(diào)用:】
default QueryChainWrapper<T> query(); // 普通鏈?zhǔn)讲樵?/span>
default LambdaQueryChainWrapper<T> lambdaQuery(); // 支持 Lambda 表達(dá)式的修改
default UpdateChainWrapper<T> update(); // 普通鏈?zhǔn)叫薷?/span>
default LambdaUpdateChainWrapper<T> lambdaUpdate(); // 支持 Lambda 表達(dá)式的修改
注:
query 表示查詢
update 表示修改
Lambda 表示內(nèi)部支持 Lambda 寫(xiě)法。
形如:
query().eq("column", value).one();
lambdaQuery().eq(Entity::getId, value).list();
update().eq("column", value).remove();
lambdaUpdate().eq(Entity::getId, value).update(entity);
二、Dao層
【添加數(shù)據(jù):(增)】
int insert(T entity); // 插入一條記錄
注:
T 表示任意實(shí)體類型
entity 表示實(shí)體對(duì)象
【刪除數(shù)據(jù):(刪)】
int deleteById(Serializable id); // 根據(jù)主鍵 ID 刪除
int deleteByMap(@Param(Constants.COLUMN_MAP) Map<String, Object> columnMap); // 根據(jù) map 定義字段的條件刪除
int delete(@Param(Constants.WRAPPER) Wrapper<T> wrapper); // 根據(jù)實(shí)體類定義的 條件刪除對(duì)象
int deleteBatchIds(@Param(Constants.COLLECTION) Collection<? extends Serializable> idList); // 進(jìn)行批量刪除
注:
id 表示 主鍵 ID
columnMap 表示表字段的 map 對(duì)象
wrapper 表示實(shí)體對(duì)象封裝操作類,可以為 null。
idList 表示 主鍵 ID 集合(列表、數(shù)組),不能為 null 或 empty
【修改數(shù)據(jù):(改)】
int updateById(@Param(Constants.ENTITY) T entity); // 根據(jù) ID 修改實(shí)體對(duì)象。
int update(@Param(Constants.ENTITY) T entity, @Param(Constants.WRAPPER) Wrapper<T> updateWrapper); // 根據(jù) updateWrapper 條件修改實(shí)體對(duì)象
注:
update 中的 entity 為 set 條件,可以為 null。
updateWrapper 表示實(shí)體對(duì)象封裝操作類(可以為 null,里面的 entity 用于生成 where 語(yǔ)句)
【查詢數(shù)據(jù):(查)】
T selectById(Serializable id); // 根據(jù) 主鍵 ID 查詢數(shù)據(jù)
List<T> selectBatchIds(@Param(Constants.COLLECTION) Collection<? extends Serializable> idList); // 進(jìn)行批量查詢
List<T> selectByMap(@Param(Constants.COLUMN_MAP) Map<String, Object> columnMap); // 根據(jù)表字段條件查詢
T selectOne(@Param(Constants.WRAPPER) Wrapper<T> queryWrapper); // 根據(jù)實(shí)體類封裝對(duì)象 查詢一條記錄
Integer selectCount(@Param(Constants.WRAPPER) Wrapper<T> queryWrapper); // 查詢記錄的總條數(shù)
List<T> selectList(@Param(Constants.WRAPPER) Wrapper<T> queryWrapper); // 查詢所有記錄(返回 entity 集合)
List<Map<String, Object>> selectMaps(@Param(Constants.WRAPPER) Wrapper<T> queryWrapper); // 查詢所有記錄(返回 map 集合)
List<Object> selectObjs(@Param(Constants.WRAPPER) Wrapper<T> queryWrapper); // 查詢所有記錄(但只保存第一個(gè)字段的值)
<E extends IPage<T>> E selectPage(E page, @Param(Constants.WRAPPER) Wrapper<T> queryWrapper); // 查詢所有記錄(返回 entity 集合),分頁(yè)
<E extends IPage<Map<String, Object>>> E selectMapsPage(E page, @Param(Constants.WRAPPER) Wrapper<T> queryWrapper); // 查詢所有記錄(返回 map 集合),分頁(yè)
注:
queryWrapper 表示實(shí)體對(duì)象封裝操作類(可以為 null)
page 表示分頁(yè)查詢條件
原文鏈接:https://blog.csdn.net/qq_37823919/article/details/123016056
相關(guān)推薦
- 2022-03-30 C語(yǔ)言入門之淺談數(shù)據(jù)類型和變量常量_C 語(yǔ)言
- 2022-12-02 C語(yǔ)言學(xué)習(xí)之指針的使用詳解_C 語(yǔ)言
- 2022-01-20 簡(jiǎn)易登錄表單的制作,包括用戶名、密碼、隨機(jī)驗(yàn)證碼(代碼完整,復(fù)制即用)
- 2021-12-04 Linux超詳細(xì)gcc升級(jí)全過(guò)程_Linux
- 2022-08-03 Django框架中表單的用法_python
- 2022-05-02 Redis使用命令行與多數(shù)據(jù)庫(kù)配置_Redis
- 2022-08-12 如何實(shí)現(xiàn)在pycharm中將.ui文件轉(zhuǎn)化為.py文件_python
- 2023-03-26 WPF使用觸發(fā)器需要注意優(yōu)先級(jí)問(wèn)題解決_C#教程
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過(guò)濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡(jiǎn)單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支