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

MyBatis-Plus聯(lián)表查詢以及分頁代碼實(shí)例

 更新時間:2023年06月08日 09:43:43   作者:李長淵哦  
在開發(fā)中遇到了一個問題,需要進(jìn)行聯(lián)表查詢并進(jìn)行分頁,因?yàn)椴幌胱约簛韺懛猪?所以還是依靠MybatisPlus來實(shí)現(xiàn)想要的功能,下面這篇文章主要給大家介紹了關(guān)于MyBatis-Plus聯(lián)表查詢以及分頁的相關(guān)資料,需要的朋友可以參考下

一、準(zhǔn)備工作

mybatis-plus作為mybatis的增強(qiáng)工具,它的出現(xiàn)極大的簡化了開發(fā)中的數(shù)據(jù)庫操作,但是長久以來,它的聯(lián)表查詢能力一直被大家所詬病。一旦遇到left join或right join的左右連接,你還是得老老實(shí)實(shí)的打開xml文件,手寫上一大段的sql語句。

直到前幾天,偶然碰到了這么一款叫做mybatis-plus-join的工具(后面就簡稱mpj了),使用了一下,不得不說真香!徹底將我從xml地獄中解放了出來,終于可以以類似mybatis-plus中QueryWrapper的方式來進(jìn)行聯(lián)表查詢了,話不多說,我們下面開始體驗(yàn)。

  • mapper繼承MPJBaseMapper (必選)
  • service繼承MPJBaseService (可選)
  • serviceImpl繼承MPJBaseServiceImpl (可選)

1、數(shù)據(jù)庫結(jié)構(gòu)以及數(shù)據(jù)

CREATE TABLE `op_product` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `type` varchar(255) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;
INSERT INTO `test_yjdsns`.`op_product`(`id`, `type`) VALUES (1, '蘋果');
CREATE TABLE `op_product_info` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `product_id` int(11) NOT NULL,
  `name` varchar(255) DEFAULT NULL,
  `price` decimal(10,2) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;
INSERT INTO `test_yjdsns`.`op_product_info`(`id`, `product_id`, `name`, `price`) VALUES (1, 1, '蘋果13', 8.00);
INSERT INTO `test_yjdsns`.`op_product_info`(`id`, `product_id`, `name`, `price`) VALUES (2, 1, '蘋果15', 9.00);

2、依賴

<dependency>
    <groupId>com.github.yulichang</groupId>
    <artifactId>mybatis-plus-join</artifactId>
    <version>1.2.4</version>
</dependency>
<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-boot-starter</artifactId>
    <version>3.5.1</version>
</dependency>

3、配置類讓mybatis-plus-join在DataScopeSqlInjector中生效

/**
 * @author licy
 * @description
 * @date 2022/10/20
 */
@Configuration
public class MybatisPlusConfig {
    /**
     * 新增分頁攔截器,并設(shè)置數(shù)據(jù)庫類型為mysql
     *
     * @return
     */
    @Bean
    public MybatisPlusInterceptor mybatisPlusInterceptor() {
        MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
        //分頁插件
        interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));
        return interceptor;
    }
    /**
     * sql注入
     */
    @Bean
    @Primary
    public MySqlInjector myLogicSqlInjector() {
        return new MySqlInjector();
    }
}

修改DataScopeSqlInjector中的繼承類為:MPJSqlInjector

public class MySqlInjector extends MPJSqlInjector {
    @Override
    public List<AbstractMethod> getMethodList(Class<?> mapperClass) {
        //將原來的保持
        List<AbstractMethod> methodList = super.getMethodList(mapperClass);
        //多表查詢sql注入 從連表插件里移植過來的
        methodList.add(new SelectJoinOne());
        methodList.add(new SelectJoinList());
        methodList.add(new SelectJoinPage());
        methodList.add(new SelectJoinMap());
        methodList.add(new SelectJoinMaps());
        methodList.add(new SelectJoinMapsPage());
        return methodList;
    }
}

4、啟動類排除MPJSqlInjector.class

@SpringBootApplication(exclude = {MPJSqlInjector.class})

載入自定義配置類

@Configuration

@MapperScan可以選擇tk下的路徑

import tk.mybatis.spring.annotation.MapperScan;

二、代碼

1、實(shí)體類

/**
 * @author licy
 * @description
 * @date 2022/10/25
 */
@Data
@NoArgsConstructor
@AllArgsConstructor
@TableName("op_product")
public class OpProduct implements Serializable {
    private static final long serialVersionUID = -3918932563888251866L;
    @TableId(value = "ID", type = IdType.AUTO)
    private Long id;
    @TableField("TYPE")
    private String type;
}
/**
 * @author licy
 * @description
 * @date 2022/10/25
 */
@Data
@NoArgsConstructor
@AllArgsConstructor
@TableName("op_product_info")
public class OpProductInfo implements Serializable {
    private static final long serialVersionUID = 4186082342917210485L;
    @TableId(value = "ID", type = IdType.AUTO)
    private Long id;
    @TableField("PRODUCT_ID")
    private Long productId;
    @TableField("NAME")
    private String name;
    @TableField("PRICE")
    private Double price;
}
/**
 * @author licy
 * @description
 * @date 2022/10/25
 */
@Data
@NoArgsConstructor
@AllArgsConstructor
public class ProductDTO implements Serializable {
    private static final long serialVersionUID = -2281333877153304329L;
    private Long id;
    private String type;
    private String name;
    private Double price;
}

2、Mapper

/**
 * @author licy
 * @description
 * @date 2022/10/26
 */
public interface OpProductInfoMapper extends MPJBaseMapper<OpProductInfo> {
}
/**
 * @author licy
 * @description
 * @date 2022/10/25
 */
public interface OpProductMapper extends MPJBaseMapper<OpProduct> {
}

3、Service

Mapper接口改造完成后,我們把它注入到Service中,雖然說我們要完成3張表的聯(lián)表查詢,但是以O(shè)pProduct作為主表的話,那么只注入這一個對應(yīng)的OpProductMapper就可以,非常簡單。

public interface OpProductService extends MPJBaseService<OpProduct> {
    List<ProductDTO> queryAllProduct();
}
@Service
@Slf4j
@AllArgsConstructor
public class OpProductServiceImpl extends MPJBaseServiceImpl<OpProductMapper, OpProduct> implements OpProductService {
    @Resource
    private OpProductMapper opProductMapper;
    @Override
    public List<ProductDTO> queryAllProduct() {
        MPJLambdaWrapper mpjLambdaWrapper = new MPJLambdaWrapper<ProductDTO>()
                .selectAll(OpProduct.class)//查詢表1的全部字段
                .selectAll(OpProductInfo.class)//查詢表2的全部字段
                .leftJoin(OpProductInfo.class, OpProductInfo::getProductId, OpProduct::getId);//左查詢表2條件為表二的productId=表一的id
        List<ProductDTO> list = opProductMapper.selectJoinList(ProductDTO.class, mpjLambdaWrapper);
        return list;
    }
}

4、測試

@SpringBootTest
@Slf4j
public class MybatisJoinTests {
    @Autowired
    private OpProductService opProductService;
    @Test
    void test1() {
        List<ProductDTO> productDTOS = opProductService.queryAllProduct();
        log.info(productDTOS.toString());
    }
}

5、結(jié)果

三、分頁查詢

1、MPJLambdaWrapper幾個方法

接下來的MPJLambdaWrapper就是構(gòu)建查詢條件的核心了,看一下我們在上面用到的幾個方法:

  • selectAll():查詢指定實(shí)體類的全部字段
  • select():查詢指定的字段,支持可變長參數(shù)同時查詢多個字段,但是在同一個select中只能查詢相同表的字段,所以如果查詢多張表的字段需要分開寫
  • selectAs():字段別名查詢,用于數(shù)據(jù)庫字段與接收結(jié)果的dto中屬性名稱不一致時轉(zhuǎn)換
  • leftJoin():左連接,其中第一個參數(shù)是參與聯(lián)表的表對應(yīng)的實(shí)體類,第二個參數(shù)是這張表聯(lián)表的ON字段,第三個參數(shù)是參與聯(lián)表的ON的另一個實(shí)體類屬性

除此之外,還可以正常調(diào)用mybatis-plus中的各種原生方法,文檔中還提到,默認(rèn)主表別名是t,其他的表別名以先后調(diào)用的順序使用t1、t2、t3以此類推。

和mybatis-plus非常類似,除了LamdaWrapper外還提供了普通QueryWrapper的寫法,舉例代碼:

public void getOrderSimple() {
     List<xxxxxDto> list = xxxxxMapper.selectJoinList(xxxxx.class,
     new MPJQueryWrapper<xxxxx>()
      .selectAll(xxxxx.class)
      .select("t2.unit_price","t2.name as product_name")
      .select("t1.name as user_name")
      .leftJoin("t_user t1 on t1.id = t.user_id")
      .leftJoin("t_product t2 on t2.id = t.product_id")
      .eq("t.status", "3")
    );
    log.info(list.toString());
}

或者

        MPJLambdaWrapper mpjLambdaWrapper = new MPJLambdaWrapper<ProductDTO>()
                .selectAll(OpProduct.class)//查詢表1的全部字段
                .selectAs(OpProductInfo::getId,"ProductInfoId")//起別名
                .selectAs(OpProductInfo::getName,ProductDTO::getName)//起別名
                .selectAs(OpProductInfo::getPrice,ProductDTO::getPrice)//起別名
                .leftJoin(OpProductInfo.class, OpProductInfo::getProductId, OpProduct::getId);//左查詢表2條件為表二的productId=表一的id
        List<ProductDTO> list = opProductMapper.selectJoinList(ProductDTO.class, mpjLambdaWrapper);
        return list;

2、分頁代碼舉例

    public IPage<ProductDTO> queryPageProduct(Integer pageNo, Integer pageCount) {
        MPJLambdaWrapper mpjLambdaWrapper = new MPJLambdaWrapper<ProductDTO>()
                .selectAll(OpProduct.class)//查詢表1的全部字段
                .selectAll(OpProductInfo.class)//查詢表2的全部字段
                .leftJoin(OpProductInfo.class, OpProductInfo::getProductId, OpProduct::getId);//左查詢表2條件為表二的productId=表一的id
        IPage<ProductDTO> page = opProductMapper.selectJoinPage(new Page<ProductDTO>(pageNo, pageCount), ProductDTO.class, mpjLambdaWrapper);
        return page;
    }

總結(jié)

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

相關(guān)文章

  • Idea中maven項(xiàng)目實(shí)現(xiàn)登錄驗(yàn)證碼功能

    Idea中maven項(xiàng)目實(shí)現(xiàn)登錄驗(yàn)證碼功能

    這篇文章主要介紹了Idea中maven項(xiàng)目實(shí)現(xiàn)登錄驗(yàn)證碼功能,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-12-12
  • java按鈕控件數(shù)組實(shí)現(xiàn)計(jì)算器界面示例分享

    java按鈕控件數(shù)組實(shí)現(xiàn)計(jì)算器界面示例分享

    本文主要介紹了JAVA通過按鈕數(shù)組來管理界面中的所有按鈕控件,從而使用最少的代碼實(shí)現(xiàn)模擬的計(jì)算器界面
    2014-02-02
  • Java中幾種常用數(shù)據(jù)庫連接池的使用

    Java中幾種常用數(shù)據(jù)庫連接池的使用

    數(shù)據(jù)庫連接池在編寫應(yīng)用服務(wù)是經(jīng)常需要用到的模塊,太過頻繁的連接數(shù)據(jù)庫對服務(wù)性能來講是一個瓶頸,使用緩沖池技術(shù)可以來消除這個瓶頸,本文就來介紹Java常見的幾種,感興趣的可以了解一下
    2021-05-05
  • JAVA JNI原理詳細(xì)介紹及簡單實(shí)例代碼

    JAVA JNI原理詳細(xì)介紹及簡單實(shí)例代碼

    這篇文章主要介紹了JAVA JNI原理的相關(guān)資料,這里提供簡單實(shí)例代碼,需要的朋友可以參考下
    2016-12-12
  • 一文搞懂Spring?Security異常處理機(jī)制

    一文搞懂Spring?Security異常處理機(jī)制

    這篇文章主要為大家詳細(xì)介紹一下Spring?Security異常處理機(jī)制,文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)Spring?Security有一定幫助,感興趣的可以學(xué)習(xí)一下
    2022-07-07
  • SpringBoot的三大開發(fā)工具小結(jié)

    SpringBoot的三大開發(fā)工具小結(jié)

    本文主要介紹了SpringBoot的三大開發(fā)工具,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-02-02
  • 詳解批處理框架之Spring Batch

    詳解批處理框架之Spring Batch

    Spring Batch是一個輕量級的、完善的批處理框架,作為Spring體系中的一員,它擁有靈活、方便、生產(chǎn)可用的特點(diǎn)。在應(yīng)對高效處理大量信息、定時處理大量數(shù)據(jù)等場景十分簡便。結(jié)合調(diào)度框架能更大地發(fā)揮Spring Batch的作用
    2021-06-06
  • screw?Maven插件方式運(yùn)行時在編譯打包時跳過執(zhí)行的問題解決方法

    screw?Maven插件方式運(yùn)行時在編譯打包時跳過執(zhí)行的問題解決方法

    這篇文章主要介紹了screw?Maven插件方式運(yùn)行時在編譯打包時跳過執(zhí)行的問題解決方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-03-03
  • spring為java.util.Properties類型的屬性進(jìn)行賦值過程解析

    spring為java.util.Properties類型的屬性進(jìn)行賦值過程解析

    這篇文章主要介紹了spring為java.util.Properties類型的屬性進(jìn)行賦值過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-01-01
  • Java8 Optional優(yōu)雅空值判斷的示例代碼

    Java8 Optional優(yōu)雅空值判斷的示例代碼

    這篇文章主要介紹了Java8 Optional優(yōu)雅空值判斷的相關(guān)知識,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-05-05

最新評論