亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

詳解MyBatis-Plus Wrapper條件構(gòu)造器查詢大全

 更新時間:2020年08月24日 10:41:58   作者:IT賤男  
這篇文章主要介紹了詳解MyBatis-Plus Wrapper條件構(gòu)造器查詢大全,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

一、引言

那么那么那么今天來說下MP中強(qiáng)大的條件查詢功能。

本章是基于上個案例來講的:MyBaits-Plus 快速入門案例

二、具體操作

首先來說說基本的查詢吧,根據(jù)主鍵或者簡單的查詢條件進(jìn)行查詢。

  /**
   * 通過單個ID主鍵進(jìn)行查詢
   */
  @Test
  public void selectById() {
    User user = userMapper.selectById(1094592041087729666L);
    System.out.println(user);
  }

  /**
   * 通過多個ID主鍵查詢
   */
  @Test
  public void selectByList() {
    List<Long> longs = Arrays.asList(1094592041087729666L, 1094590409767661570L);
    List<User> users = userMapper.selectBatchIds(longs);
    users.forEach(System.out::println);
  }

  /**
   * 通過Map參數(shù)進(jìn)行查詢
   */
  @Test
  public void selectByMap() {
    Map<String, Object> params = new HashMap<>();
    params.put("name", "張雨琪");
    List<User> users = userMapper.selectByMap(params);
    users.forEach(System.out::println);
  }


MyBatis-Plus還提供了Wrapper條件構(gòu)造器,具體使用看如下代碼:

/**
   * 名字包含雨并且年齡小于40
   * <p>
   * WHERE name LIKE '%雨%' AND age < 40
   */
  @Test
  public void selectByWrapperOne() {
    QueryWrapper<User> wrapper = new QueryWrapper();
    wrapper.like("name", "雨").lt("age", 40);
    List<User> users = userMapper.selectList(wrapper);
    users.forEach(System.out::println);
  }

  /**
   * 名字包含雨
   * 年齡大于20小于40
   * 郵箱不能為空
   * <p>
   * WHERE name LIKE '%雨%' AND age BETWEEN 20 AND 40 AND email IS NOT NULL
   */
  @Test
  public void selectByWrapperTwo() {
    QueryWrapper<User> wrapper = Wrappers.query();
    wrapper.like("name", "雨").between("age", 20, 40).isNotNull("email");
    List<User> users = userMapper.selectList(wrapper);
    users.forEach(System.out::println);
  }

  /**
   * 名字為王性
   * 或者年齡大于等于25
   * 按照年齡降序排序,年齡相同按照id升序排序
   * <p>
   * WHERE name LIKE '王%' OR age >= 25 ORDER BY age DESC , id ASC
   */
  @Test
  public void selectByWrapperThree() {
    QueryWrapper<User> wrapper = Wrappers.query();
    wrapper.likeRight("name", "王").or()
        .ge("age", 25).orderByDesc("age").orderByAsc("id");
    List<User> users = userMapper.selectList(wrapper);
    users.forEach(System.out::println);
  }

  /**
   * 查詢創(chuàng)建時間為2019年2月14
   * 并且上級領(lǐng)導(dǎo)姓王
   * <p>
   * WHERE date_format(create_time,'%Y-%m-%d') = '2019-02-14' AND manager_id IN (select id from user where name like '王%')
   */
  @Test
  public void selectByWrapperFour() {
    QueryWrapper<User> wrapper = Wrappers.query();
    wrapper.apply("date_format(create_time,'%Y-%m-%d') = {0}", "2019-02-14")
        .inSql("manager_id", "select id from user where name like '王%'");
    List<User> users = userMapper.selectList(wrapper);
    users.forEach(System.out::println);
  }

  /**
   * 查詢王姓
   * 并且年齡小于40或者郵箱不為空
   * <p>
   * WHERE name LIKE '王%' AND ( age < 40 OR email IS NOT NULL )
   */
  @Test
  public void selectByWrapperFive() {
    QueryWrapper<User> wrapper = Wrappers.query();
    wrapper.likeRight("name", "王").and(qw -> qw.lt("age", 40).or().isNotNull("email"));
    List<User> users = userMapper.selectList(wrapper);
    users.forEach(System.out::println);
  }

  /**
   * 查詢王姓
   * 并且年齡大于20 、年齡小于40、郵箱不能為空
   * <p>
   * WHERE name LIKE ? OR ( age BETWEEN ? AND ? AND email IS NOT NULL )
   */
  @Test
  public void selectByWrapperSix() {
    QueryWrapper<User> wrapper = Wrappers.query();
    wrapper.likeRight("name", "王").or(
        qw -> qw.between("age", 20, 40).isNotNull("email")
    );
    List<User> users = userMapper.selectList(wrapper);
    users.forEach(System.out::println);
  }

  /**
   * (年齡小于40或者郵箱不為空) 并且名字姓王
   * WHERE ( age < 40 OR email IS NOT NULL ) AND name LIKE '王%'
   */
  @Test
  public void selectByWrapperSeven() {
    QueryWrapper<User> wrapper = Wrappers.query();
    wrapper.nested(qw -> qw.lt("age", 40).or().isNotNull("email"))
        .likeRight("name", "王");
    List<User> users = userMapper.selectList(wrapper);
    users.forEach(System.out::println);
  }

  /**
   * 查詢年齡為30、31、32
   * WHERE age IN (?,?,?)
   */
  @Test
  public void selectByWrapperEight() {
    QueryWrapper<User> wrapper = Wrappers.query();
    wrapper.in("age", Arrays.asList(30, 31, 32));
    List<User> users = userMapper.selectList(wrapper);
    users.forEach(System.out::println);
  }

  /**
   * 查詢一條數(shù)據(jù)
   * limit 1
   */
  @Test
  public void selectByWrapperNine() {
    QueryWrapper<User> wrapper = Wrappers.query();
    wrapper.in("age", Arrays.asList(30, 31, 32)).last("limit 1");
    List<User> users = userMapper.selectList(wrapper);
    users.forEach(System.out::println);
  }

到此這篇關(guān)于詳解MyBatis-Plus Wrapper條件構(gòu)造器查詢大全的文章就介紹到這了,更多相關(guān) MyBatis-Plus Wrapper條件構(gòu)造器內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • SpringBoot使用PropertiesLauncher加載外部jar包

    SpringBoot使用PropertiesLauncher加載外部jar包

    這篇文章主要介紹了SpringBoot使用PropertiesLauncher加載外部jar包,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-07-07
  • Java數(shù)組與字符串深入探索使用方法

    Java數(shù)組與字符串深入探索使用方法

    在今天的文章中,我將為你詳細(xì)講述Java學(xué)習(xí)中重要的一節(jié) [ 數(shù)組與字符串 ] ,帶你深入了解Java語言中數(shù)組的聲明、創(chuàng)建和初始化方法,字符串的定義以及常用到的操作方法
    2022-07-07
  • Java快速排序及求數(shù)組中第k小的值解析

    Java快速排序及求數(shù)組中第k小的值解析

    這篇文章主要介紹了Java快速排序及求數(shù)組中第k小的值解析,選一個中間值,把數(shù)組中比它小的元素放到左邊,比它大的元素放到右邊,這時形成三個子數(shù)組,分別是中間值,比它大的數(shù)和比它小的數(shù),然后對前后兩個數(shù)組進(jìn)行遞歸,需要的朋友可以參考下
    2023-11-11
  • 使用java8 API遍歷過濾文件目錄及子目錄和隱藏文件示例詳解

    使用java8 API遍歷過濾文件目錄及子目錄和隱藏文件示例詳解

    這篇文章主要介紹了使用java8API遍歷過濾文件目錄及子目錄及隱藏文件示例詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • 關(guān)于Java企業(yè)級項(xiàng)目開發(fā)思想

    關(guān)于Java企業(yè)級項(xiàng)目開發(fā)思想

    Java企業(yè)級項(xiàng)目開發(fā)思想。偶遇,讀有所得,遂分享給大家,本文不涉及案例,只談思想和理念,需要的朋友可以參考。
    2017-09-09
  • SpringBoot整合Elasticsearch游標(biāo)查詢的示例代碼(scroll)

    SpringBoot整合Elasticsearch游標(biāo)查詢的示例代碼(scroll)

    這篇文章主要介紹了SpringBoot整合Elasticsearch游標(biāo)查詢(scroll),本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-10-10
  • Mybatis動態(tài)SQL之if、choose、where、set、trim、foreach標(biāo)記實(shí)例詳解

    Mybatis動態(tài)SQL之if、choose、where、set、trim、foreach標(biāo)記實(shí)例詳解

    動態(tài)SQL就是動態(tài)的生成SQL。接下來通過本文給大家介紹Mybatis動態(tài)SQL之if、choose、where、set、trim、foreach標(biāo)記實(shí)例詳解的相關(guān)知識,感興趣的朋友一起看看吧
    2016-09-09
  • IDEA項(xiàng)目重命名的操作

    IDEA項(xiàng)目重命名的操作

    這篇文章主要介紹了IDEA項(xiàng)目重命名的操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-02-02
  • logback標(biāo)記日志過濾器MarkerFilter源碼解讀

    logback標(biāo)記日志過濾器MarkerFilter源碼解讀

    這篇文章主要為大家介紹了logback標(biāo)記日志過濾器MarkerFilter源碼解讀,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-11-11
  • Spring源碼解析之BeanPostProcessor知識總結(jié)

    Spring源碼解析之BeanPostProcessor知識總結(jié)

    今天給大家?guī)淼奈恼率荢pring的相關(guān)知識,文章圍繞著BeanPostProcessor的使用展開,文中有非常詳細(xì)的介紹,需要的朋友可以參考下
    2021-06-06

最新評論