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

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

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

Mybatis Plus select 查詢部分字段

Mybatis Plus select語句默認(rèn)查詢所有字段,如需要指定字段查詢,則需使用 QueryWrapper的select方法。

select

select(String... sqlSelect)  
select(Predicate<TableFieldInfo> predicate)  
select(Class<T> entityClass, Predicate<TableFieldInfo> predicate)

設(shè)置查詢字段

說明:

以上方法分為兩類。

第二類方法為:過濾查詢字段(主鍵除外),入?yún)⒉话?class 的調(diào)用前需要wrapper內(nèi)的entity屬性有值! 這兩類方法重復(fù)調(diào)用以最后一次為準(zhǔn)

例:指定查詢主鍵,名字,年齡字段

select("id", "name", "age") 

例: 查詢以test開頭的屬性

select(i ‐> i.getProperty().startsWith("test")) 

例:查詢User對象中出除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查詢測試代碼如下:

//測試根據(jù)ID查詢
@Test
public void testSelectById(){
	User user = userMapper.selectById(2L);
	System.out.println(user);
}

測試結(jié)果如下:

批量查詢測試代碼如下:

//測試批量查詢
@Test
public void testSelectByBatchIds(){
	List<User> users = userMapper.selectBatchIds(Arrays.asList(1, 2, 3));
	users.forEach(System.out::println);
}

測試結(jié)果如下:

使用map進(jìn)行條件查詢測試代碼如下:

//按條件查詢之使用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);
}

測試結(jié)果如下:

2、分頁查詢

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

2.1、在配置類里注冊分頁插件

//注冊分頁插件
@Bean
public PaginationInterceptor paginationInterceptor(){
	return new PaginationInterceptor();
}

2.2、直接使用MP內(nèi)置的Page對象進(jìn)行分頁,測試代碼如下

@Test
public void testPage(){
	//參數(shù)1:當(dāng)前頁,參數(shù)2:頁面大小
	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());
}

測試結(jié)果如下:

二、Mybatis-Plus之刪除操作

1、物理刪除操作常用API

根據(jù)ID刪除測試代碼如下:

//測試刪除
@Test
public void testDeleteById(){
	userMapper.deleteById(1L);
}

測試結(jié)果如下:

根據(jù)ID批量刪除測試代碼如下:

//通過id批量刪除
@Test
public void testDeleteBatchId(){
	userMapper.deleteBatchIds(Arrays.asList(2L,3L));
}

測試結(jié)果如下:

使用map進(jìn)行條件刪除測試代碼如下:

@Test
public void testDeleteMap(){
	Map map = new HashMap();
	map.put("name","哈利油");
	userMapper.deleteByMap(map);
}

測試結(jié)果如下:

2、邏輯刪除

在工作中有時需要使用到邏輯刪除,邏輯刪除即數(shù)據(jù)在數(shù)據(jù)庫里沒有被移除,而是通過一個變量來讓它失效;一般管理員可以查看被邏輯刪除的數(shù)據(jù),這樣可防止數(shù)據(jù)的丟失,類似于回收站功能

MP邏輯刪除使用步驟如下:

2.1、在數(shù)據(jù)庫里增加deleted字段

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

2.3、在配置類里注冊邏輯刪除組件

//注冊邏輯刪除組件
@Bean
public ISqlInjector sqlInjector(){
	return new LogicSqlInjector();
}

2.4、在application.properties文件里配置已刪除跟未刪除用什么來表示

mybatis-plus.global-config.db-config.logic-delete-value=1
mybatis-plus.global-config.db-config.logic-not-delete-value=0

2.5、測試邏輯刪除

以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

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

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

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

    Spring bean生命周期配置過程解析

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

    Java程序連接數(shù)據(jù)庫的常用的類和接口介紹

    這篇文章主要介紹了Java程序連接數(shù)據(jù)庫的常用的類和接口,包括Connection類和Statement類等,需要的朋友可以參考下
    2015-10-10
  • 線程池調(diào)用kafka發(fā)送消息產(chǎn)生的內(nèi)存泄漏問題排查解決

    線程池調(diào)用kafka發(fā)送消息產(chǎn)生的內(nèi)存泄漏問題排查解決

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

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

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

    Java DFA算法案例詳解

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

    SpringBoot靜態(tài)資源的訪問方法詳細(xì)介紹

    最近在做SpringBoot項(xiàng)目的時候遇到了“白頁”問題,通過查資料對SpringBoot訪問靜態(tài)資源做了總結(jié),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2022-09-09
  • Java JSONObject與JSONArray對象案例詳解

    Java JSONObject與JSONArray對象案例詳解

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

    java操作mongodb示例分享

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

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

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

最新評論