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

MyBatis-Plus中SimpleQuery查詢實現(xiàn)

 更新時間:2022年08月10日 10:17:01   作者:Coder-CT  
本文主要介紹了MyBatis-Plus中SimpleQuery查詢實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

對list查詢后的結(jié)果用Stream流進(jìn)行了一些封裝,使其可以返回一些指定結(jié)果,簡潔了api的調(diào)用,這種調(diào)用方式不用注入bean、不用注入bean、不用注入bean,通過實體類class查詢

**SimpleQuery.list()、SimpleQuery.keyMap()**較常用

         <!--低版本沒有這個工具類-->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.5.1</version>
        </dependency>
// 獲取ID
List<Long> list = SimpleQuery.list(new QueryWrapper<HssTypePropertyEntity>()
? ? .eq("type_id",5).lambda(), HssTypePropertyEntity::getId);

// 以typeId為key分組
Map<Long, HssEquipmentEntity> map =?
? ? SimpleQuery.keyMap(new QueryWrapper<HssEquipmentEntity>()
? ? .eq("type_id", 5).lambda(),
? ? HssEquipmentEntity::getTypeId);
// 查詢角色的隱藏ID,以角色I(xiàn)D分組
Map<Long, List<Long>> columnMap =
? ? SimpleQuery.group(new QueryWrapper<SysRoleColumnEntity>().lambda(),?
? ? SysRoleColumnEntity::getRoleId,?
? ? Collectors.mapping(SysRoleColumnEntity::getColumnId, Collectors.toList()));

操作實例:

?// 我要這個表里對應(yīng)條件的用戶,用id作為key給我一個map
? ? ? ? Map<Long, Entity> idEntityMap = SimpleQuery.keyMap(Wrappers.<Entity>lambdaQuery().eq(Entity::getId, 1L), Entity::getId);
? ? ? ? // 校驗結(jié)果
? ? ? ? Entity entity = new Entity();
? ? ? ? entity.setId(1L);
? ? ? ? entity.setName("ruben");
? ? ? ? Assert.isTrue(idEntityMap.equals(Collections.singletonMap(1L, entity)), "Ops!");

? ? ? ? // 如果我只想要id和name組成的map
? ? ? ? Map<Long, String> idNameMap = SimpleQuery.map(Wrappers.lambdaQuery(), Entity::getId, Entity::getName);
? ? ? ? // 校驗結(jié)果
? ? ? ? Map<Long, String> map = new HashMap<>(1 << 2);
? ? ? ? map.put(1L, "ruben");
? ? ? ? map.put(2L, null);
? ? ? ? Assert.isTrue(idNameMap.equals(map), "Ops!");
? ? }

? ? @Test
? ? public void testGroup() {
? ? ? ? // 我需要相同名字的用戶的分為一組,再造一條數(shù)據(jù)
? ? ? ? doTestAutoCommit(m -> {
? ? ? ? ? ? Entity entity = new Entity();
? ? ? ? ? ? entity.setId(3L);
? ? ? ? ? ? entity.setName("ruben");
? ? ? ? ? ? m.insert(entity);
? ? ? ? });

? ? ? ? // 簡單查詢
? ? ? ? Map<String, List<Entity>> nameUsersMap = SimpleQuery.group(Wrappers.lambdaQuery(), Entity::getName);

? ? ? ? // 校驗結(jié)果
? ? ? ? Map<String, List<Entity>> map = new HashMap<>(1 << 2);
? ? ? ? Entity chao = new Entity();
? ? ? ? chao.setId(2L);
? ? ? ? chao.setName(null);
? ? ? ? map.put(null, Collections.singletonList(chao));

? ? ? ? Entity ruben = new Entity();
? ? ? ? ruben.setId(1L);
? ? ? ? ruben.setName("ruben");
? ? ? ? Entity ruben2 = new Entity();
? ? ? ? ruben2.setId(3L);
? ? ? ? ruben2.setName("ruben");
? ? ? ? map.put("ruben", Arrays.asList(ruben, ruben2));
? ? ? ? Assert.isTrue(nameUsersMap.equals(map), "Ops!");

? ? ? ? // 解鎖高級玩法:
? ? ? ? // 獲取Map<name,List<id>>
? ? ? ? Map<String, List<Long>> nameIdMap = SimpleQuery.group(Wrappers.lambdaQuery(), Entity::getName, Collectors.mapping(Entity::getId, Collectors.toList()));
? ? ? ? // 獲取Map<name,個數(shù)>
? ? ? ? Map<String, Long> nameCountMap = SimpleQuery.group(Wrappers.lambdaQuery(), Entity::getName, Collectors.counting());
? ? ? ? // ...超多花樣
? ? }

? ? @Override
? ? protected String tableDataSql() {
? ? ? ? return "insert into entity(id,name) values(1,'ruben'),(2,null);";
? ? }

? ? @Override
? ? protected List<String> tableSql() {
? ? ? ? return Arrays.asList("drop table if exists entity", "CREATE TABLE IF NOT EXISTS entity (" +
? ? ? ? ? ? "id BIGINT NOT NULL," +
? ? ? ? ? ? "name VARCHAR(30) NULL DEFAULT NULL," +
? ? ? ? ? ? "PRIMARY KEY (id))");
? ? }

當(dāng)然原來的查詢也可以,只是還需要注入bean才能操作,listObjs(wrapper,mapper)

List<Long> strings = 
hssTypePropertyService.listObjs(new QueryWrapper<HssTypePropertyEntity>()
    .select("id").eq("type_id", 5)
    ,i->Long.valueOf(i.toString()));

ActiveRecord (查詢)模式

說明:

  • 實體類只需繼承 Model 類即可進(jìn)行強大的 CRUD 操作
  • 需要項目中已注入對應(yīng)實體的BaseMapper

實體繼承 Model,調(diào)用自mapper,省去注入!

@Data
@TableName(value = "hss_history", autoResultMap = true)
public class HssHistoryEntity extends Model<HssHistoryEntity> implements Serializable {
    private static final long serialVersionUID = 1L;
    @TableId
    private Long id;
    // json映射,autoResultMap必須開啟,寫了xml查詢需要resultMap映射字段
    //查詢映射<result column="data" property="data" typeHandler="com.baomidou.mybatisplus.extension.handlers.JacksonTypeHandler" javaType="com.alibaba.fastjson.JSONObject"/>
    //更新映射#{e.data,jdbcType=VARCHAR,typeHandler=com.baomidou.mybatisplus.extension.handlers.JacksonTypeHandler},
    @TableField(typeHandler = JacksonTypeHandler.class)
    private JSONObject data;  
}

創(chuàng)建對象直接就可以使用crud,省去注入

HssHistoryEntity entity = new HssHistoryEntity();
// 創(chuàng)建對象直接就有crud了
entity.insert();
entity.selectList(new QueryWrapper<HssHistoryEntity>());
entity.updateById();
entity.deleteById();

到此這篇關(guān)于MyBatis-Plus中SimpleQuery查詢實現(xiàn)的文章就介紹到這了,更多相關(guān)MyBatis-Plus SimpleQuery查詢內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳解SpringBoot如何實現(xiàn)緩存預(yù)熱

    詳解SpringBoot如何實現(xiàn)緩存預(yù)熱

    緩存預(yù)熱是指在 Spring Boot 項目啟動時,預(yù)先將數(shù)據(jù)加載到緩存系統(tǒng)(如 Redis)中的一種機制,下面我們就來看看SpringBoot是如何實現(xiàn)緩存預(yù)熱的吧
    2024-01-01
  • Java如何調(diào)用TSC打印機進(jìn)行打印詳解

    Java如何調(diào)用TSC打印機進(jìn)行打印詳解

    這篇文章主要給大家介紹了關(guān)于Java如何調(diào)用TSC打印機進(jìn)行打印的相關(guān)資料,文中介紹了三種方法,分別是兩種后臺打印以及JS打印 ,三種方法都給出了詳細(xì)的示例代碼,需要的朋友可以參考借鑒,下面來一起看看吧
    2018-07-07
  • 解決SpringBoot集成Eureka導(dǎo)致返回結(jié)果由json變?yōu)閤ml的問題

    解決SpringBoot集成Eureka導(dǎo)致返回結(jié)果由json變?yōu)閤ml的問題

    這篇文章主要介紹了解決SpringBoot集成Eureka導(dǎo)致返回結(jié)果由json變?yōu)閤ml的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • java基礎(chǔ)的詳細(xì)了解第二天

    java基礎(chǔ)的詳細(xì)了解第二天

    這篇文章對Java編程語言的基礎(chǔ)知識作了一個較為全面的匯總,在這里給大家分享一下。需要的朋友可以參考,希望能給你帶來幫助
    2021-08-08
  • java基礎(chǔ)的詳細(xì)了解第三天

    java基礎(chǔ)的詳細(xì)了解第三天

    這篇文章對Java編程語言的基礎(chǔ)知識作了一個較為全面的匯總,在這里給大家分享一下。需要的朋友可以參考,希望能給你帶來幫助
    2021-08-08
  • 使用Gradle做Java代碼質(zhì)量檢查的方法示例

    使用Gradle做Java代碼質(zhì)量檢查的方法示例

    這篇文章主要介紹了使用Gradle做Java代碼質(zhì)量檢查的方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-03-03
  • springmvc項目使用@Valid+BindingResult遇到的問題

    springmvc項目使用@Valid+BindingResult遇到的問題

    這篇文章主要介紹了springmvc項目使用@Valid+BindingResult遇到的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-12-12
  • 帶你了解Java數(shù)據(jù)結(jié)構(gòu)和算法之前綴,中綴和后綴表達(dá)式

    帶你了解Java數(shù)據(jù)結(jié)構(gòu)和算法之前綴,中綴和后綴表達(dá)式

    這篇文章主要為大家介紹了Java的前綴,中綴和后綴表達(dá)式 ,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-01-01
  • java模擬實現(xiàn)雙向鏈表

    java模擬實現(xiàn)雙向鏈表

    這篇文章主要為大家詳細(xì)介紹了java模擬實現(xiàn)雙向鏈表,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • Nacos集群搭建過程詳解

    Nacos集群搭建過程詳解

    這篇文章主要為大家介紹了Nacos集群搭建過程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-05-05

最新評論