Bootstrap

Springboot + MongoDB 大容量数据分页及条件查询(千万数据量级别)

直接上代码

1. 新建查询类 QueryData

package com.example.basedata.bean;

import java.util.HashMap;
import java.util.List;

public class QueryData {

    private String tableName;

    private Integer pageNum;

    private Integer pageSize;

    private HashMap<String, String> conditions;

    public Integer getPageNum() {
        return pageNum;
    }

    public void setPageNum(Integer pageNum) {
        this.pageNum = pageNum;
    }

    public Integer getPageSize() {
        return pageSize;
    }

    public void setPageSize(Integer pageSize) {
        this.pageSize = pageSize;
    }

    public HashMap<String, String> getConditions() {
        return conditions;
    }

    public void setConditions(HashMap<String, String> conditions) {
        this.conditions = conditions;
    }

    public String getTableName() {
        return tableName;
    }

    public void setTableName(String tableName) {
        this.tableName = tableName;
    }

    @Override
    public String toString() {
        return "QueryData{" +
                "tableName='" + tableName + '\'' +
                ", pageNum=" + pageNum +
                ", pageSize=" + pageSize +
                ", conditions=" + conditions +
                '}';
    }
}

2. Control 层

package com.example.basedata.controller;

import com.alibaba.fastjson.JSONObject;
import com.example.basedata.bean.*;
import com.example.basedata.service.CommonDataServe;
import io.swagger.annotations.ApiOperation;
import org.springframework.web.bind.annotation.*;

import javax.annotation.Resource;
import java.util.List;

@RestController
@RequestMapping("/data")
@CrossOrigin(value = "*",  maxAge = 3600)
public class CommonDataControl {

    @Resource
    private CommonDataServe serve;

//  @ApiOperation(value="多条件分页查询", notes="多条件分页查询指定表")
    @RequestMapping(value = "/query", method = RequestMethod.POST)
    public JSONObject queryData(@RequestBody QueryData queryData) {
        JSONObject output = new JSONObject();
        serve.getData(queryData, output);
        return output;
    }
}

3. Serve 层

package com.example.basedata.service;

import com.alibaba.fastjson.JSONObject;
import com.example.basedata.bean.*;
import com.example.basedata.dao.impl.CommonDataImpl;
import com.example.basedata.dao.impl.TableInfoImpl;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Service;

import javax.annotation.Resource;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;

@Service
public class CommonDataServe {

    @Resource
    private CommonDataImpl commonDataImpl;

    public JSONObject getData(QueryData queryData, JSONObject result) {
        String tableName = queryData.getTableName();
        int pageNum = queryData.getPageNum();
        int pageSize = queryData.getPageSize();
        HashMap<String, String> conditions = queryData.getConditions();

        List list1 = commonDataImpl.getData(pageNum, pageSize, tableName, conditions);
        result.put("status", 200);
        result.put("msg", "success");
        result.put("data", list1);
        return result;
    }
}

4. CommonDataImpl 类

package com.example.basedata.dao.impl;

import com.example.basedata.bean.DeleteFields;
import com.example.basedata.bean.Extract;
import com.mongodb.MongoNamespace;
import com.mongodb.client.MongoCollection;
import com.mongodb.client.MongoDatabase;
import com.mongodb.client.model.RenameCollectionOptions;
import org.springframework.data.mongodb.core.MongoTemplate;
import org.springframework.data.mongodb.core.query.Criteria;
import org.springframework.data.mongodb.core.query.Query;
import org.springframework.stereotype.Repository;

import javax.annotation.Resource;
import java.util.HashMap;
import java.util.List;
import java.util.concurrent.CountDownLatch;

@Repository
public class CommonDataImpl {

    @Resource
    private MongoTemplate template;

    @Resource
    private AsyncTestImpl asyncTestImpl;

    public List getData(int pageNum, int pageSize, String tableName, HashMap<String, String> conditions) {
        //创建查询对象
        Query query = new Query();
        //设置起始数
        query.skip((pageNum - 1) * pageSize);
        //设置查询条数
        query.limit(pageSize);
        if (conditions != null) {
            for (String field: conditions.keySet()) {
                query.addCriteria(new Criteria(field).is(conditions.get(field)));
            }
        }
        return template.find(query, Object.class, tableName);
    }
}

5. 程序测试

测试的目标库表数据量为1000多万

 

 

 成功返回,且花费时间仅为220ms,接下来加上查询条件

 

 

成功返回,且花费时间仅为24ms

;