IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> mongodb文档集合中元素查询 -> 正文阅读

[大数据]mongodb文档集合中元素查询

数据库其中一条数据格式如下:

{
? ? "_id": "6220a1942fefba0066659",
? ? "formDataId": "d885b3094c24160b3756997d59fe5175",
? ? "formStructId": "cfed43eb74bab08ca36eb8343319d98e",
? ? "qrCodeId": "2a445726c47ed0b344a0546abf09ac00",
? ? "data": {
? ? ? ? "list": [
? ? ? ? ? ? {
? ? ? ? ? ? ? ? "valueLabel": "88",
? ? ? ? ? ? ? ? "name": "姓名",
? ? ? ? ? ? ? ? "icon": "iconfont icon-a-xingmingxiao",
? ? ? ? ? ? ? ? "options": {
? ? ? ? ? ? ? ? ? ? "clearable": false,
? ? ? ? ? ? ? ? ? ? "maxlength": "50",
? ? ? ? ? ? ? ? ? ? "defaultValue": "",
? ? ? ? ? ? ? ? ? ? "placeholder": "请输入姓名",
? ? ? ? ? ? ? ? ? ? "required": false
? ? ? ? ? ? ? ? },
? ? ? ? ? ? ? ? "screen": false,
? ? ? ? ? ? ? ? "type": "input",
? ? ? ? ? ? ? ? "labelName": "姓名",
? ? ? ? ? ? ? ? "title": "",
? ? ? ? ? ? ? ? "value": "",
? ? ? ? ? ? ? ? "tips": "请如实填写",
? ? ? ? ? ? ? ? "key": "5b87fc3c-660c-455f-bdd0-0be475498fcd",
? ? ? ? ? ? ? ? "defaultType": NumberInt("0")
? ? ? ? ? ? },
? ? ? ? ? ? {
? ? ? ? ? ? ? ? "valueLabel": "男",
? ? ? ? ? ? ? ? "name": "性别",
? ? ? ? ? ? ? ? "icon": "iconfont icon-a-xingbiexiao",
? ? ? ? ? ? ? ? "options": {
? ? ? ? ? ? ? ? ? ? "defaultValue": "",
? ? ? ? ? ? ? ? ? ? "block": true,
? ? ? ? ? ? ? ? ? ? "required": false,
? ? ? ? ? ? ? ? ? ? "valueData": [
? ? ? ? ? ? ? ? ? ? ? ? {
? ? ? ? ? ? ? ? ? ? ? ? ? ? "label": "男",
? ? ? ? ? ? ? ? ? ? ? ? ? ? "key": NumberInt("1")
? ? ? ? ? ? ? ? ? ? ? ? },
? ? ? ? ? ? ? ? ? ? ? ? {
? ? ? ? ? ? ? ? ? ? ? ? ? ? "label": "女",
? ? ? ? ? ? ? ? ? ? ? ? ? ? "key": NumberInt("0")
? ? ? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? ? ? ]
? ? ? ? ? ? ? ? },
? ? ? ? ? ? ? ? "screen": false,
? ? ? ? ? ? ? ? "type": "radio",
? ? ? ? ? ? ? ? "labelName": "性别",
? ? ? ? ? ? ? ? "title": "",
? ? ? ? ? ? ? ? "value": "03",
? ? ? ? ? ? ? ? "tips": "",
? ? ? ? ? ? ? ? "key": "d01bf58b-436c-41b4-b869-fba60a354c65",
? ? ? ? ? ? ? ? "defaultType": NumberInt("0")
? ? ? ? ? ? },
? ? ? ? ? ? {
? ? ? ? ? ? ? ? "valueLabel": "1788888888",
? ? ? ? ? ? ? ? "name": "手机号",
? ? ? ? ? ? ? ? "icon": "iconfont icon-shoujihao",
? ? ? ? ? ? ? ? "options": {
? ? ? ? ? ? ? ? ? ? "clearable": false,
? ? ? ? ? ? ? ? ? ? "maxlength": "11",
? ? ? ? ? ? ? ? ? ? "defaultValue": "",
? ? ? ? ? ? ? ? ? ? "placeholder": "请输入手机号",
? ? ? ? ? ? ? ? ? ? "required": false
? ? ? ? ? ? ? ? },
? ? ? ? ? ? ? ? "screen": false,
? ? ? ? ? ? ? ? "type": "input",
? ? ? ? ? ? ? ? "labelName": "手机号",
? ? ? ? ? ? ? ? "title": "",
? ? ? ? ? ? ? ? "value": "",
? ? ? ? ? ? ? ? "tips": "",
? ? ? ? ? ? ? ? "key": "d21d1708-efba-468b-8ce6-16f0f243ed41",
? ? ? ? ? ? ? ? "defaultType": NumberInt("0")
? ? ? ? ? ? },
? ? ? ? ? ? {
? ? ? ? ? ? ? ? "valueLabel": "",
? ? ? ? ? ? ? ? "name": "邮箱",
? ? ? ? ? ? ? ? "icon": "iconfont icon-youxiang",
? ? ? ? ? ? ? ? "options": {
? ? ? ? ? ? ? ? ? ? "clearable": false,
? ? ? ? ? ? ? ? ? ? "maxlength": "50",
? ? ? ? ? ? ? ? ? ? "defaultValue": "",
? ? ? ? ? ? ? ? ? ? "placeholder": "请输入邮箱",
? ? ? ? ? ? ? ? ? ? "required": false
? ? ? ? ? ? ? ? },
? ? ? ? ? ? ? ? "screen": false,
? ? ? ? ? ? ? ? "type": "input",
? ? ? ? ? ? ? ? "labelName": "邮箱",
? ? ? ? ? ? ? ? "title": "",
? ? ? ? ? ? ? ? "value": "",
? ? ? ? ? ? ? ? "tips": "",
? ? ? ? ? ? ? ? "key": "95d36d9a-4992-4f84-97dc-c3637b4f87ab",
? ? ? ? ? ? ? ? "defaultType": NumberInt("0")
? ? ? ? ? ? }
? ? ? ? ]
? ? },
? ? "createBy": NumberLong("2138991"),
? ? "createAt": ISODate("2022-03-03T09:04:32.619Z"),
? ? "updateBy": NumberLong("2138991"),
? ? "updateAt": ISODate("2022-03-03T09:04:32.619Z"),
? ? "deleted": NumberInt("0"),
? ? "_class": "net.trueland.tcloud.qrcode.entity.FormDataMongoEntity"
}

需求:根据data字段中list集合中 name = "姓名",valueLabel="88"模糊查询? 两个条件在list下的同一个元素对象中必须同时满足,查询数据库中符合条件的数据

?

SQL:

db.T_Cloud_Form_Data.find({"data.list":{$elemMatch:{"name":"姓名","value":{ $regex:'88'}}}})

代码:

 Query query = new Query();
        Criteria criteria = new Criteria();

        criteria.and("formStructId").is(req.getFormStructId());
        // 筛选条件
        if (StringUtils.isNotBlank(screeningName) && StringUtils.isNotBlank(filterContent)) {
            filterContent = EscapeUtil.escapeExprSpecialWord(filterContent);
            String pattern = ".*" + filterContent + ".*";
            Criteria cri = Criteria.where("name").is(screeningName).and("value").regex(pattern);
            criteria.and("data.list").elemMatch(cri);
            log.info("条件criteria:{}",criteria);
        }
        criteria.and("deleted").ne(1);
        query.addCriteria(criteria);
        query.with(PageRequest.of(req.getPageNum() - 1, req.getPageSize(), Sort.by(Sort.Order.desc("createAt"))));
        List<FormDataMongoEntity> data = mongoTemplate.find(query, FormDataMongoEntity.class, "T_Cloud_Form_Data");

需求二:根据data字段中list集合中 name = "姓名",valueLabel="88"模糊查询? 两个条件在list数组对象中(此种情况不要求在数组下同一个元素对象中)同时满足,查询数据库中符合条件的数据

SQL:

db.T_Cloud_Form_Data.find({"formStructId":"35a551482d374ac4cfd2cbb9ae219208","data.list.name":"姓名","data.list.value":{ $regex:'88'}})

代码:


        Query query = new Query();
        Criteria criteria = new Criteria();
        criteria.and("formStructId").is(req.getFormStructId());
        // 筛选条件
        if (StringUtils.isNotBlank(screeningName) && StringUtils.isNotBlank(filterContent)) {
            criteria.and("data.list.name").is(screeningName);
            filterContent = EscapeUtil.escapeExprSpecialWord(filterContent);
            String pattern = ".*" + filterContent + ".*";
            criteria.and("data.list.value").regex(pattern); // 模糊查询
        }
        criteria.and("deleted").ne(1);
        query.addCriteria(criteria);
        query.with(PageRequest.of(req.getPageNum() - 1, req.getPageSize(), Sort.by(Sort.Order.desc("createAt"))));
        List<FormDataMongoEntity> data = mongoTemplate.find(query, FormDataMongoEntity.class, "T_Cloud_Form_Data");
        long count = mongoTemplate.count(query, FormDataMongoEntity.class, "T_Cloud_Form_Data");

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-03-16 22:27:35  更:2022-03-16 22:29:35 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 7:38:04-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码