当前位置: 首页 > news >正文

ElasticSearch 查询方法示例 java

public List<PricePolicyConditionDTO> queryEs(OrderPriceOutDTO param, List<String> materialCodeList, List<String> categoryCodeList) {BoolQueryBuilder mainQueryBoolBuilder = new BoolQueryBuilder();//销售组织if (CharSequenceUtil.isNotEmpty(param.getSalesOrgCode())) {mainQueryBoolBuilder.must(QueryBuilders.termQuery(PricePolicyEsDataDTO.Fields.salesOrgCode + KEYWORD_SUFFIX, param.getSalesOrgCode()));}//价格类型if (CharSequenceUtil.isNotEmpty(param.getPriceTypeName())) {mainQueryBoolBuilder.must(QueryBuilders.termQuery(PricePolicyEsDataDTO.Fields.priceType + KEYWORD_SUFFIX, param.getPriceTypeName()));}//and ((policy_type = 'Foc') or (policy_type != 'Foc' and currency= #{currncy}))if (CharSequenceUtil.isNotEmpty(param.getCurrency())) {BoolQueryBuilder query1 = QueryBuilders.boolQuery();query1.must(QueryBuilders.termQuery(PricePolicyEsDataDTO.Fields.policyType + KEYWORD_SUFFIX, CommonConstant.FOC));BoolQueryBuilder query2 = QueryBuilders.boolQuery();query2.mustNot(QueryBuilders.termsQuery(PricePolicyEsDataDTO.Fields.policyType + KEYWORD_SUFFIX, CommonConstant.FOC));query2.must(QueryBuilders.termQuery(PricePolicyEsDataDTO.Fields.currency + KEYWORD_SUFFIX, param.getCurrency()));BoolQueryBuilder query3 = QueryBuilders.boolQuery();query3.should(query1);query3.should(query2);mainQueryBoolBuilder.must(query3);}//and policy_start_date >= sysdaye() and  policy_end_date <= sysdaye()mainQueryBoolBuilder.must(QueryBuilders.rangeQuery(PricePolicyEsDataDTO.Fields.policyStartDate).lte(LocalTimeUnit.getNowTime()));mainQueryBoolBuilder.must(QueryBuilders.rangeQuery(PricePolicyEsDataDTO.Fields.policyEndDate).gte(LocalTimeUnit.getNowTime()));// and [  (object_type = 'Product' and (object_code like '' or object_code like '' ) ) OR//  (object_type = 'ProductCategory' and (object_code like '' or object_code like '' ) )//  ]if (CollUtil.isNotEmpty(materialCodeList) || CollUtil.isNotEmpty(categoryCodeList)) {BoolQueryBuilder query4 = QueryBuilders.boolQuery();if (CollUtil.isNotEmpty(materialCodeList)) {BoolQueryBuilder query3 = QueryBuilders.boolQuery();BoolQueryBuilder query1 = QueryBuilders.boolQuery();query1.must(QueryBuilders.termQuery(PricePolicyEsDataDTO.Fields.objectType + KEYWORD_SUFFIX, CommonConstant.PRODUCT));query3.must(query1);BoolQueryBuilder query2 = QueryBuilders.boolQuery();materialCodeList.forEach(v -> {WildcardQueryBuilder queryBuilder1 = QueryBuilders.wildcardQuery(PricePolicyEsDataDTO.Fields.objectCode + KEYWORD_SUFFIX, "*" + v + "*");query2.should(queryBuilder1);});query3.must(query2);query4.should(query3);}if (CollUtil.isNotEmpty(categoryCodeList)) {BoolQueryBuilder query3 = QueryBuilders.boolQuery();BoolQueryBuilder query1 = QueryBuilders.boolQuery();query1.must(QueryBuilders.termQuery(PricePolicyEsDataDTO.Fields.objectType + KEYWORD_SUFFIX, CommonConstant.PRODUCT_CATEGORY));query3.must(query1);BoolQueryBuilder query2 = QueryBuilders.boolQuery();categoryCodeList.forEach(v -> {WildcardQueryBuilder queryBuilder1 = QueryBuilders.wildcardQuery(PricePolicyEsDataDTO.Fields.objectCode + KEYWORD_SUFFIX, "*" + v + "*");query2.should(queryBuilder1);});query3.must(query2);query4.should(query3);}mainQueryBoolBuilder.must(query4);}Query query = new NativeSearchQueryBuilder().withQuery(mainQueryBoolBuilder).build();SearchHits<PricePolicyEsDataDTO> searchHits = elasticsearchRestTemplate.search(query, PricePolicyEsDataDTO.class);List<PricePolicyEsDataDTO> collect = searchHits.getSearchHits().stream().map(SearchHit::getContent).collect(Collectors.toList());List<PricePolicyConditionDTO> policyConditionList = BeanUtil.copyToList(collect, PricePolicyConditionDTO.class);return dataScopeFilter(param, policyConditionList);}

相关文章:

ElasticSearch 查询方法示例 java

public List<PricePolicyConditionDTO> queryEs(OrderPriceOutDTO param, List<String> materialCodeList, List<String> categoryCodeList) {BoolQueryBuilder mainQueryBoolBuilder new BoolQueryBuilder();//销售组织if (CharSequenceUtil.isNotEmpty(pa…...

5G毫米波通信中的关键技术

随着5G技术的快速发展&#xff0c;毫米波通信作为其中的一项重要技术&#xff0c;在高速数据传输、低延迟通信和大规模连接等方面具有显著的优势。本文将探讨5G毫米波通信中的关键技术&#xff0c;包括毫米波频段的选择、信号处理技术和MIMO技术等。 一、毫米波频段的选择 毫米…...

2.3.3 交换机的RSTP技术

实验2.3.3 交换机的RSTP技术 一、任务描述二、任务分析三、具体要求四、实验拓扑五、任务实施1.交换机的基本配置。2.开启交换机的STP。3.配置SW3A和SW3B上STP的优先级。将SW3A配置为根交换机&#xff0c;SW3B配置为备用根交换机。4.配置SW2A和SW2B的边缘接口 六、任务验收七、…...

国外访问学者/博士后留学人员反诈骗指南

访问学者/博士后/联合培养博士人员出国后&#xff0c;对当地环境及政策不熟悉&#xff0c;需要提高防范意识&#xff0c;为此&#xff0c;知识人网小编特整理这篇反诈骗指南&#xff0c;提醒留学人员防微杜渐、未雨绸缪。 近日&#xff0c;多国使馆发布相关提醒&#xff1a;不法…...

设计模式之组合模式-创建层次化的对象结构

目录 概述概念主要角色应用场景 组合模式的实现类图NS图基本代码组合模式的精髓意外收获&#xff08;❀❀&#xff09; 应用示例-公司组织架构管理需求结构图代码 组合模式的优缺点优点缺点 总结 概述 概念 组合模式是一种结构型设计模式&#xff0c;它允许将对象组合成树形结…...

Windows 有趣功能集锦

Windows 有趣功能集锦 隐藏文件或文件夹 CMD 运行以下命令隐藏 # attrib h <文件或文件夹名称> attrib r h s a 测试显示 # attrib h <文件或文件夹名称> attrib -r -h -s -a 测试使视频显示为图片 准备一个视频文件和一个需要显示的图片先将视频压缩成压缩文…...

【nodejs版playwright】02-支持多套测试环环境执行用例

日常测试中&#xff0c;一套测试用例需支持在不同的测试环境运行&#xff0c;如staging、production 因为涉及不同的测试环境&#xff0c;那使用的环境变量或参数就不一样&#xff0c;如staging登录可能用到的用户名是A&#xff0c;而production可能用到的是b。 所以需要有一个…...

React高阶组件(Higher-Order Components, HOCs)

React 高阶组件 (Higher Order Components, HOCs) 是一种模式&#xff0c;让组件具备一定的扩展能力。它是函数式编程思想在 React 应用程序中的体现。HOCs 可以让你重用组件&#xff0c;提高组件的可复用性。 HOCs 是什么&#xff1f; 高阶组件实际上是一个函数&#xff0c;…...

利用RoboBrowser库和爬虫代理实现微博视频的爬取

技术概述 微博是一个社交媒体平台&#xff0c;用户可以在上面发布和分享各种内容&#xff0c;包括文字、图片、音频和视频。微博视频是微博上的一种重要的内容形式&#xff0c;有时我们可能想要下载微博视频到本地&#xff0c;以便于观看或分析。但是&#xff0c;微博视频并没…...

使用Redis实现缓存及对应问题解决

一、为什么需要Redis作缓存&#xff1f; 在业务场景中&#xff0c;如果有些数据需要极高频的存取&#xff0c;每次都要在mysql中查询的话代价太大&#xff0c;假如有一个存在于客户端和mysql之间的存储空间&#xff0c;每次可以在这空间中进行存取操作&#xff0c;就会减轻mys…...

【穿透科技】P2P穿透模块介绍

P2P穿透+一站式音视频解决方案路过看风景P2P隧道模块(pgLibTunnel) 1.功能介绍 P2P隧道是在Peergine中间件基础上实现的一个TCP隧道应用(通过P2P来传输TCP流量),包括服务器和客户端程序。它可以协助从公网或者从另一私网访问某个私网内部的计算机和网络设备。其优点是无需…...

中国第二批,11个大模型备案获批

加上首批的 10 余个大模型&#xff0c;目前已有超过 20 个大模型获得审批。 据钛媒体独家报道&#xff0c;国内第二批通过备案的AI大模型包括11家公司&#xff0c;部分已面向全社会开放服务。加上首批的10余个大模型&#xff0c;目前已有超过20个大模型获得备案。 新一批备案…...

一文搞定多端开发,做全栈大牛 附三大企业实战项目

一个功能三套代码 一改需求就是加不完的班&#xff1f; 不存在的&#xff0c;告别改改改 拥抱多端开发 一套代码搞定多个平台 高效开发&#xff1a;一套代码&#xff0c;多端通用 根据统计数据&#xff0c;全球移动设备用户数已经超过了50亿。随着智能手机、平板电脑等移动…...

带有滑动菜单指示器的纯 CSS 导航选项卡

效果展示 CSS 知识点 filter 属性回顾 transition 属性回顾 使用单选框实现导航菜单的思路 单选框当点击完成后就会有一个:checked属性&#xff0c;可以利用这个属性来实现导航菜单底部滑动块的滑动动画和当前菜单项激活状态的管理。 整体页面结构 <div class"tab…...

Java学习笔记41——接口组成更新

接口祖成更新 接口组成更新接口组成更新概述接口的组成接口中的默认方法接口中的静态方法接口中的私有方法 接口组成更新 接口组成更新概述 接口的组成 常量 public static final 抽象方法 public abstract 默认方法&#xff08;Java8&#xff09;静态方法&#xff08;Java8…...

iview实现table里面每行数据的跳转

我的需求是跳转到第三方网站&#xff0c;看官方是写了如何跳转站内路由&#xff0c;不符合我的要求&#xff0c;在csdn发现了一篇文章&#xff0c;我贴一下代码 <template><Table border :columns"ReportColumns" :data"ReportData"><templ…...

Docker快速搭建Drupal内容管理系统并远程访问

&#x1f3ac; 鸽芷咕&#xff1a;个人主页 &#x1f525;个人专栏:《Linux深造日志》《C干货基地》 ⛺️生活的理想&#xff0c;就是为了理想的生活! 文章目录 前言1. Docker安装Drupal2. 本地局域网访问3 . Linux 安装cpolar4. 配置Drupal公网访问地址5. 公网远程访问Drupal…...

Ansible优化大全

文章目录 一、关闭系统信息收集二、开启加速 Ansible 执行速度修改配置文件/etc/ansible/ansible.cfg由于该功能与sudo冲突&#xff0c;必须关闭 requiretty 选项方法一方法二 参考文章&#xff1a; https://blog.csdn.net/o0o0o0D/article/details/110998873 一、关闭系统信息…...

Python|OpenCV-图像的添加和混合操作(8)

前言 本文是该专栏的第8篇,后面将持续分享OpenCV计算机视觉的干货知识,记得关注。 在使用OpenCV库对图像操作的时候,有时需要对图像进行运算操作,类似于加法,减法,位操作等处理。而本文,笔者将针对OpenCV对图像的添加,混合以及位操作进行详细的介绍说明和使用。 下面,…...

Vue3+vite+cesium环境搭建

引言 目前有不少vue3cesium的配置教学&#xff0c;存在以下两个问题&#xff1a; &#xff08;1&#xff09;vue3cli方式&#xff0c;随着项目的迭代&#xff0c;npm run serve 启动调试很慢&#xff1b; &#xff08;2&#xff09;vue3vite 确实能将调试启动提升不少的&…...

高通平台Android HAL层读写NV分区实战:从源码路径到完整Demo(Android O/R)

高通平台Android HAL层NV分区操作深度解析与实战指南 在Android设备生产与维护过程中&#xff0c;设备唯一标识&#xff08;如IMEI、序列号等&#xff09;的可靠管理是确保设备可追溯性和功能完整性的关键环节。这些关键数据通常存储在高通平台的NV分区中&#xff0c;而如何安全…...

终极指南:10分钟掌握Deno高性能HTTP服务器开发

终极指南&#xff1a;10分钟掌握Deno高性能HTTP服务器开发 【免费下载链接】deno A modern runtime for JavaScript and TypeScript. 项目地址: https://gitcode.com/GitHub_Trending/de/deno Deno是一个现代JavaScript和TypeScript运行时&#xff0c;提供了简单高效的H…...

告别HttpCanary!手把手教你用Python搭建Frida RPC服务器,实现Burp实时篡改加密请求

用Python构建Frida RPC网关&#xff1a;Burp与移动端加密流量的深度交互方案 移动应用安全测试中&#xff0c;最令人头疼的莫过于遇到加密流量。当你发现HttpCanary能捕获请求而BurpSuite却束手无策时&#xff0c;传统解决方案往往需要在多个工具间频繁切换&#xff0c;效率低下…...

当车间老师傅遇上AI调度员:深度强化学习在真实产线中的试错与成长日记

当车间老师傅遇上AI调度员&#xff1a;深度强化学习在真实产线中的试错与成长日记 1. 传统调度遇上智能革命 走进任何一家离散制造工厂的车间&#xff0c;你总能看到几位眉头紧锁的老师傅站在排程板前&#xff0c;手中的记号笔在密密麻麻的工序卡间来回游走。他们的大脑就像一台…...

UABEAvalonia:跨平台Unity资源编辑器的完整使用指南

UABEAvalonia&#xff1a;跨平台Unity资源编辑器的完整使用指南 【免费下载链接】UABEA c# uabe for newer versions of unity 项目地址: https://gitcode.com/gh_mirrors/ua/UABEA UABEAvalonia是一款基于C#开发的跨平台Unity资源编辑器&#xff0c;专为现代Unity引擎版…...

PHP进程管理利器:轻量级工具pao的原理、配置与实战

1. 项目概述&#xff1a;一个轻量级的PHP进程管理器如果你在PHP开发中&#xff0c;特别是处理后台任务、队列消费或者需要管理长时间运行的脚本时&#xff0c;还在为进程的启动、停止、重启和监控而头疼&#xff0c;那么nunomaduro/pao这个项目绝对值得你花时间了解一下。它不是…...

XUnity自动翻译器终极指南:5分钟让任何Unity游戏变中文版

XUnity自动翻译器终极指南&#xff1a;5分钟让任何Unity游戏变中文版 【免费下载链接】XUnity.AutoTranslator 项目地址: https://gitcode.com/gh_mirrors/xu/XUnity.AutoTranslator 还在为外语游戏而烦恼吗&#xff1f;XUnity自动翻译器是你的终极解决方案&#xff01…...

Qwen3.5-9B-AWQ-4bit Qt桌面应用开发:跨平台AI助手客户端

Qwen3.5-9B-AWQ-4bit Qt桌面应用开发&#xff1a;跨平台AI助手客户端 1. 为什么需要本地化AI助手 在数字化办公场景中&#xff0c;我们经常遇到需要快速获取信息、处理文档或编写代码的需求。传统的云端AI服务虽然强大&#xff0c;但存在响应延迟、隐私顾虑和网络依赖等问题。…...

为什么WHERE中的函数调用会引发灾难?揭秘KES与Oracle的函数执行顺序之谜

在 WHERE 子句里放一个"有副作用"的函数&#xff0c;就像在高速公路上放了一个随机变道的司机——也许今天没事&#xff0c;但迟早会出事故。引言&#xff1a;一段看起来"理所当然"的代码在一次代码评审中&#xff0c;我看到了这样一条 SQL&#xff1a;SEL…...

天赐范式第23天:上篇是过程,这篇是结果,基于算子化筛选的MOF催化剂高通量发现系统

&#x1f680; 摘要感觉和前文很像是吧&#xff01;是就对了&#xff0c;上篇是过程&#xff0c;这篇是结果。材料筛选是材料科学研究的核心瓶颈。传统的试错法和单一DFT计算效率低下&#xff0c;难以应对海量材料空间的探索需求。本文提出天赐范式 v5.16&#xff0c;一种基于四…...