Mybatis Plus select 實(shí)現(xiàn)只查詢部分字段
Mybatis Plus select 查詢部分字段
Mybatis Plus select語(yǔ)句默認(rèn)查詢所有字段,如需要指定字段查詢,則需使用 QueryWrapper的select方法。
select
select(String... sqlSelect) select(Predicate<TableFieldInfo> predicate) select(Class<T> entityClass, Predicate<TableFieldInfo> predicate)
設(shè)置查詢字段
說(shuō)明:
以上方法分為兩類。
第二類方法為:過(guò)濾查詢字段(主鍵除外),入?yún)⒉话?class 的調(diào)用前需要wrapper內(nèi)的entity屬性有值! 這兩類方法重復(fù)調(diào)用以最后一次為準(zhǔn)
例:指定查詢主鍵,名字,年齡字段
select("id", "name", "age")
例: 查詢以test開(kāi)頭的屬性
select(i ‐> i.getProperty().startsWith("test"))
例:查詢User對(duì)象中出除manager_id和create_time外其它所有字段的數(shù)據(jù)
select(User.class, info ‐> !info.getColumn().equals("manager_id")
&& !info.getColumn().equals("create_time"))
MyBatis-Plus之select、delete
一、Mybatis-Plus之查詢操作
1、查詢操作常用API
根據(jù)ID查詢測(cè)試代碼如下:
//測(cè)試根據(jù)ID查詢
@Test
public void testSelectById(){
User user = userMapper.selectById(2L);
System.out.println(user);
}
測(cè)試結(jié)果如下:

批量查詢測(cè)試代碼如下:
//測(cè)試批量查詢
@Test
public void testSelectByBatchIds(){
List<User> users = userMapper.selectBatchIds(Arrays.asList(1, 2, 3));
users.forEach(System.out::println);
}
測(cè)試結(jié)果如下:

使用map進(jìn)行條件查詢測(cè)試代碼如下:
//按條件查詢之使用map操作
@Test
public void testSelectByMap(){
Map map = new HashMap();
map.put("name","哈利油");
map.put("age",18);
List list = userMapper.selectByMap(map);
list.forEach(System.out::println);
}
測(cè)試結(jié)果如下:

2、分頁(yè)查詢
分頁(yè)在項(xiàng)目里使用得十分多,平時(shí)一般是使用pageHelpr插件進(jìn)行分頁(yè),還可以使用原始的limit進(jìn)行分頁(yè);MP其實(shí)內(nèi)置了分頁(yè)插件,使用步驟如下:
2.1、在配置類里注冊(cè)分頁(yè)插件

//注冊(cè)分頁(yè)插件
@Bean
public PaginationInterceptor paginationInterceptor(){
return new PaginationInterceptor();
}
2.2、直接使用MP內(nèi)置的Page對(duì)象進(jìn)行分頁(yè),測(cè)試代碼如下
@Test
public void testPage(){
//參數(shù)1:當(dāng)前頁(yè),參數(shù)2:頁(yè)面大小
Page<User> page = new Page<>(1,5);
//用于排序
page.setDesc("id");
IPage<User> userIPage = userMapper.selectPage(page, null);
userIPage.getRecords().forEach(System.out::println);
System.out.println(userIPage.getTotal());
}
測(cè)試結(jié)果如下:

二、Mybatis-Plus之刪除操作
1、物理刪除操作常用API
根據(jù)ID刪除測(cè)試代碼如下:
//測(cè)試刪除
@Test
public void testDeleteById(){
userMapper.deleteById(1L);
}
測(cè)試結(jié)果如下:

根據(jù)ID批量刪除測(cè)試代碼如下:
//通過(guò)id批量刪除
@Test
public void testDeleteBatchId(){
userMapper.deleteBatchIds(Arrays.asList(2L,3L));
}
測(cè)試結(jié)果如下:

使用map進(jìn)行條件刪除測(cè)試代碼如下:
@Test
public void testDeleteMap(){
Map map = new HashMap();
map.put("name","哈利油");
userMapper.deleteByMap(map);
}
測(cè)試結(jié)果如下:

2、邏輯刪除
在工作中有時(shí)需要使用到邏輯刪除,邏輯刪除即數(shù)據(jù)在數(shù)據(jù)庫(kù)里沒(méi)有被移除,而是通過(guò)一個(gè)變量來(lái)讓它失效;一般管理員可以查看被邏輯刪除的數(shù)據(jù),這樣可防止數(shù)據(jù)的丟失,類似于回收站功能
MP邏輯刪除使用步驟如下:
2.1、在數(shù)據(jù)庫(kù)里增加deleted字段

2.2、在實(shí)體類對(duì)應(yīng)的屬性上加上@TableLogic注解

2.3、在配置類里注冊(cè)邏輯刪除組件

//注冊(cè)邏輯刪除組件
@Bean
public ISqlInjector sqlInjector(){
return new LogicSqlInjector();
}
2.4、在application.properties文件里配置已刪除跟未刪除用什么來(lái)表示

mybatis-plus.global-config.db-config.logic-delete-value=1 mybatis-plus.global-config.db-config.logic-not-delete-value=0
2.5、測(cè)試邏輯刪除



以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Java程序連接數(shù)據(jù)庫(kù)的常用的類和接口介紹
這篇文章主要介紹了Java程序連接數(shù)據(jù)庫(kù)的常用的類和接口,包括Connection類和Statement類等,需要的朋友可以參考下2015-10-10
線程池調(diào)用kafka發(fā)送消息產(chǎn)生的內(nèi)存泄漏問(wèn)題排查解決
這篇文章主要為大家介紹了線程池調(diào)用kafka發(fā)送消息產(chǎn)生的內(nèi)存泄漏問(wèn)題排查解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08
spring cloud Hystrix斷路器的使用(熔斷器)
這篇文章主要介紹了spring cloud Hystrix斷路器的使用(熔斷器),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-08-08
SpringBoot靜態(tài)資源的訪問(wèn)方法詳細(xì)介紹
最近在做SpringBoot項(xiàng)目的時(shí)候遇到了“白頁(yè)”問(wèn)題,通過(guò)查資料對(duì)SpringBoot訪問(wèn)靜態(tài)資源做了總結(jié),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧2022-09-09
Java JSONObject與JSONArray對(duì)象案例詳解
這篇文章主要介紹了Java JSONObject與JSONArray對(duì)象案例詳解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-09-09
基于idea 的 Java中的get/set方法之優(yōu)雅的寫法
這篇文章主要介紹了基于idea 的 Java中的get/set方法之優(yōu)雅的寫法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-01-01

