欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mybatis Plus select 實(shí)現(xiàn)只查詢部分字段

 更新時(shí)間:2021年09月01日 17:21:41   作者:etna  
這篇文章主要介紹了Mybatis Plus select 實(shí)現(xiàn)只查詢部分字段的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

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基于UDP協(xié)議的聊天室功能

    Java基于UDP協(xié)議的聊天室功能

    這篇文章主要為大家詳細(xì)介紹了Java基于UDP協(xié)議的聊天室功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-09-09
  • Spring bean生命周期配置過(guò)程解析

    Spring bean生命周期配置過(guò)程解析

    這篇文章主要介紹了Spring bean生命周期配置過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-03-03
  • Java程序連接數(shù)據(jù)庫(kù)的常用的類和接口介紹

    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)題排查解決

    這篇文章主要為大家介紹了線程池調(diào)用kafka發(fā)送消息產(chǎn)生的內(nèi)存泄漏問(wèn)題排查解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-08-08
  • spring cloud Hystrix斷路器的使用(熔斷器)

    spring cloud Hystrix斷路器的使用(熔斷器)

    這篇文章主要介紹了spring cloud Hystrix斷路器的使用(熔斷器),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-08-08
  • Java DFA算法案例詳解

    Java DFA算法案例詳解

    這篇文章主要介紹了Java DFA算法案例詳解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • SpringBoot靜態(tài)資源的訪問(wèn)方法詳細(xì)介紹

    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ì)象案例詳解

    這篇文章主要介紹了Java JSONObject與JSONArray對(duì)象案例詳解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-09-09
  • java操作mongodb示例分享

    java操作mongodb示例分享

    這篇文章主要介紹了java操作mongodb示例,實(shí)現(xiàn)了簡(jiǎn)單的條件查詢和復(fù)雜的條件查詢,需要的朋友可以參考下
    2014-02-02
  • 基于idea 的 Java中的get/set方法之優(yōu)雅的寫(xiě)法

    基于idea 的 Java中的get/set方法之優(yōu)雅的寫(xiě)法

    這篇文章主要介紹了基于idea 的 Java中的get/set方法之優(yōu)雅的寫(xiě)法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-01-01

最新評(píng)論