elastic search java api 向量搜索实践 / java结合es实现 以图搜图

准备数据

图片数据

1. FunctionScoreQueryBuilder 方式

代码

//构建脚本查询
Script script = new Script(
        Script.DEFAULT_SCRIPT_TYPE,
        "painless",
        //pic_vector - 搜索字段
        "cosineSimilarity(params.queryVector, doc['pic_vector']) + 1.0",
        new HashMap<String, Object>() {{
            //searchData.getPicVector() - 需要搜索的向量数组,List<Double> 类型
            put("queryVector", searchData.getPicVector());
        }});
ScriptScoreFunctionBuilder scriptScoreFunctionBuilder = ScoreFunctionBuilders.scriptFunction(script);

//构建普通查询
BoolQueryBuilder boolQueryBuilder = QueryBuilders.boolQuery();
// 只查存在的数据
boolQueryBuilder.filter(QueryBuilders.termQuery(FieldGetterUtil.getPropName(searchData::getState), ConstantEnum.ONE.code));
// 查询名称
if (StringUtils.isNotBlank(searchData.getName())) {
    boolQueryBuilder.filter(QueryBuilders.termQuery(FieldGetterUtil.getPropName(searchData::getName), searchData.getName()));
}

// 构建查询请求
SearchRequest searchRequest = new SearchRequest("picture");
SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
FunctionScoreQueryBuilder functionScoreQueryBuilder = QueryBuilders.functionScoreQuery(boolQueryBuilder, scriptScoreFunctionBuilder);
searchSourceBuilder.query(functionScoreQueryBuilder);
searchRequest.source(searchSourceBuilder);

// 执行搜索
SearchResponse searchResponse = null;
try {
    searchResponse = restHighLevelClient.search(searchRequest, RequestOptions.DEFAULT);
} catch (IOException e) {
    e.printStackTrace();
}

DSL

GET picture/_search
{
  "query": {
    "function_score": {
      "query": {
        "bool": {
          "filter": [
            {
              "term": {
                "state": {
                  "value": 1,
                  "boost": 1
                }
              }
            }
          ],
          "adjust_pure_negative": true,
          "boost": 1
        }
      },
      "functions": [
        {
          "filter": {
            "match_all": {
              "boost": 1
            }
          },
          "script_score": {
            "script": {
              "source": "cosineSimilarity(params.queryVector, doc['pic_vector']) + 1.0",
              "lang": "painless",
              "params": {
                "queryVector": [
                  数据太长了,先不展示了~
                ]
              }
            }
          }
        }
      ],
      "score_mode": "multiply",
      "max_boost": 3.4028235e+38,
      "boost": 1
    }
  }
}

搜索图片

duck

搜索结果

在这里插入图片描述

2. WrapperQueryBuilder 方式

代码

BoolQueryBuilder boolQueryBuilder = QueryBuilders.boolQuery();
searchRequest.source().query(boolQueryBuilder);

// 只查存在的数据
boolQueryBuilder.filter(QueryBuilders.termQuery(FieldGetterUtil.getPropName(searchData::getState), ConstantEnum.ONE.code));

// 查询拖名称
if (StringUtils.isNotBlank(searchData.getName())) {
    boolQueryBuilder.filter(QueryBuilders.termQuery(FieldGetterUtil.getPropName(searchData::getName), searchData.getName()));
}

/*
    若包含图片向量,使用 WrapperQueryBuilder 重新构建搜索 DSL 。
    这个方法要在所有条件设置完成之后调用
 */
List<Double> picVector = searchData.getPicVector();
if (CollectionUtil.isNotEmpty(picVector)) {
    buildPicVectorWrapperQueryBuilder(searchData, searchRequest);
}
//执行检索
SearchResponse searchResponse = null;
try {
    searchResponse = restHighLevelClient.search(searchRequest, RequestOptions.DEFAULT);
} catch (IOException e) {
    e.printStackTrace();
    return ElasticSearchUtil.getEmptyList();
}

/**
 * 构建向量搜索DSL
 *
 * @param searchData
 * @param searchRequest
 */
private void buildPicVectorWrapperQueryBuilder(PictureSearchParam searchData, SearchRequest searchRequest) {
    SearchSourceBuilder source = searchRequest.source();
    source.minScore(searchData.getMinCosScore());
    JSONObject boolQueryDsl = JSONObject.parseObject(source.toString()).getJSONObject("query");
    String fieldName = MapUtils.camelToUnderline(FieldGetterUtil.getPropName(searchData::getPicVector));
    JSONObject queryObject = new JSONObject();
    queryObject.
            put("script_score", new JSONObject() {{
                put("query", boolQueryDsl);
                put("script", new JSONObject() {{
                    put("source", "cosineSimilarity(params." + fieldName + ", doc['" + fieldName + "'])+1.0");
                    put("params", new JSONObject() {{
                        put(fieldName, searchData.getPicVector());
                    }});
                }});
            }});
    WrapperQueryBuilder wrapperQueryBuilder = new WrapperQueryBuilder(JSON.toJSONString(queryObject));
    searchRequest.source().query(wrapperQueryBuilder);
}

DSL

GET picture/_search
{
  "from": 0,
  "size": 10,
  "query": {
    "wrapper": {
      "query": "{"script_score":{"query":{"bool":{"filter":[{"term":{"state":{"value":1,"boost":1.0}}}],"adjust_pure_negative":true,"boost":1.0}},"script":{"source":"cosineSimilarity(params.pic_vector, doc['pic_vector'])+1.0","params":{"pic_vector":[1.6442052125930786,1.8865864276885986,1.7520954608917236,1.468852162361145,0.5215243697166443,0.7162830829620361,0.24571764469146729,1.4161274433135986,0.6646647453308105,1.3490488529205322,0.48114028573036194,0.2379283457994461,1.2469896078109741,0.08662496507167816,0.5922273993492126,0.10052661597728729,0.10489580780267715,2.9626169204711914,0.9646034240722656,0.19339174032211304,0.6715909242630005,0.04913193732500076,0.0,0.42337557673454285,0.025834018364548683,0.0,0.11716371029615402,0.6066735982894897,0.014276627451181412,2.884373903274536,1.64122474193573,1.2666609287261963,0.25835415720939636,1.1439200639724731,1.4614897966384888,0.11240338534116745,0.41580113768577576,1.0173624753952026,0.5987152457237244,1.2826963663101196,0.5032907724380493,1.057185173034668,0.547160804271698,0.05201975628733635,0.9926323890686035,0.21758079528808594,1.5080771446228027,0.8714171648025513,1.0743465423583984,0.26693201065063477,0.09906674176454544,0.6293906569480896,1.286428451538086,0.0,0.3668249547481537,0.5311413407325745,0.061351045966148376,2.250185012817383,2.789849042892456,0.15071651339530945,0.1434730738401413,0.9516364932060242,0.1407829225063324,0.25287064909935,0.17089177668094635,1.6555739641189575,0.0,0.0019493978470563889,1.3358027935028076,0.07204823940992355,0.16275016963481903,0.11294800788164139,0.5596479177474976,2.8226816654205322,0.14157873392105103,0.03585885465145111,0.9136238098144531,0.41478878259658813,1.0509036779403687,0.3129948079586029,2.0000646114349365,0.8153970837593079,1.3230550289154053,1.1095032691955566,0.28675076365470886,0.18675370514392853,0.2574092745780945,0.45135366916656494,0.016980139538645744,0.20753440260887146,0.41814732551574707,0.45569372177124023,0.3243209421634674,2.3663172721862793,0.3488512933254242,0.3961148262023926,1.2847280502319336,0.4596094787120819,0.295514315366745,0.27450114488601685,0.3971012234687805,0.09721055626869202,1.0776207447052002,1.7841401100158691,1.1067540645599365,0.47844311594963074,0.20624254643917084,0.31310611963272095,0.6461139917373657,0.7538109421730042,0.395407110452652,0.45494332909584045,0.6232404112815857,0.8919894695281982,0.07885006815195084,0.4594714045524597,0.0811014398932457,0.4367794096469879,0.38426822423934937,0.32951658964157104,0.39118894934654236,0.22487390041351318,0.8610787391662598,0.5830796957015991,0.22959084808826447,0.0,0.9512133002281189,1.5710111856460571,1.2377055883407593,0.7546780109405518,0.48969006538391113,0.01670645736157894,0.003672399092465639,0.13706518709659576,1.7633861303329468,0.0814945325255394,1.1701894998550415,1.7390072345733643,0.3970920443534851,0.12410901486873627,0.25183501839637756,0.0,0.8199000358581543,0.7423927187919617,0.6346560716629028,0.022905947640538216,0.04582146182656288,0.9695563912391663,0.12152308970689774,0.17273357510566711,0.7655898928642273,0.08139333128929138,0.07582168281078339,0.9004191756248474,0.14518927037715912,0.6863758563995361,0.1891728788614273,1.0480291843414307,0.19950711727142334,0.8628987073898315,0.5608657598495483,0.8113354444503784,1.4624766111373901,1.43254554271698,0.4083332121372223,0.34310656785964966,0.9406865835189819,0.25686052441596985,1.1322646141052246,1.3540557622909546,0.02817135490477085,0.9846411943435669,0.9473340511322021,0.011850777082145214,0.061210229992866516,1.5749471187591553,0.07743599265813828,0.021998148411512375,0.3337361216545105,1.3646867275238037,0.197146937251091,0.02684418112039566,0.12807682156562805,1.0077452659606934,0.3472479283809662,1.2218244075775146,0.09163398295640945,0.933601975440979,0.9883574843406677,0.0011759570334106684,1.3720240592956543,0.6321293711662292,0.4054896831512451,0.35202157497406006,0.9274296164512634,0.31666436791419983,0.2984192967414856,1.3704978227615356,0.5182018876075745,1.0565110445022583,0.40002939105033875,0.4459632635116577,0.040395546704530716,0.10418936610221863,0.17342320084571838,0.2005527913570404,0.8796011209487915,0.11033149808645248,1.0753612518310547,1.6421480178833008,0.8594897389411926,0.23118343949317932,0.020162638276815414,0.11008383333683014,1.025146484375,0.6431025266647339,0.3835214376449585,0.2778571844100952,0.19006343185901642,0.1956976354122162,0.33776241540908813,1.3048166036605835,0.404217928647995,0.2543957233428955,0.6464782953262329,0.11861731112003326,0.3645017445087433,0.39175671339035034,0.001248408923856914,0.21438832581043243,1.7175337076187134,0.023903202265501022,0.08463321626186371,2.3428306579589844,1.0570204257965088,0.7067260146141052,0.02989930287003517,0.5042319893836975,1.3931736946105957,2.6658830642700195,0.15046465396881104,0.06599919497966766,0.950067937374115,1.8213883638381958,1.1690945625305176,0.24541716277599335,0.2557571828365326,1.3565306663513184,0.8072720766067505,0.08816192299127579,0.35571640729904175,0.18390542268753052,0.21673527359962463,0.03435497358441353,0.6771786212921143,0.3647828698158264,0.013729920610785484,3.0426361560821533,2.367980480194092,0.5787132382392883,1.466723084449768,0.44589436054229736,0.22420497238636017,0.462899774312973,0.8461235165596008,0.8448554277420044,0.22718840837478638,0.5224109888076782,0.363288015127182,1.0595544576644897,0.7337091565132141,0.828894853591919,0.38964617252349854,0.33601781725883484,1.631548523902893,0.1084078997373581,0.0020526465959846973,0.44630682468414307,0.737890899181366,0.5049909949302673,1.5234544277191162,0.12044011056423187,0.47697144746780396,0.21996237337589264,0.03638237714767456,0.00388450943864882,1.1379690170288086,0.09419768303632736,0.04319988936185837,0.3590329587459564,0.7639684677124023,0.20068643987178802,0.03304234892129898,0.9005059003829956,0.3665461242198944,0.07220682501792908,0.4413575232028961,2.284785270690918,0.4442480802536011,0.42596006393432617,0.5397369265556335,0.48256734013557434,0.05242738127708435,0.048188235610723495,0.020073335617780685,0.28828370571136475,0.5012069344520569,0.1711190640926361,0.44558703899383545,0.11565989255905151,2.3350460529327393,0.9526135325431824,0.9658022522926331,0.5853427648544312,0.478196382522583,0.9319117069244385,3.159679412841797,0.6313217878341675,0.48193103075027466,0.4907498359680176,1.1279035806655884,0.5200980305671692,0.33537474274635315,1.0791858434677124,0.0018491842783987522,0.30037400126457214,0.3399773836135864,0.010889220982789993,0.2526705265045166,0.9613133668899536,0.5535693168640137,2.868227243423462,0.6160788536071777,0.33963432908058167,0.7948097586631775,1.3093180656433105,0.7971509695053101,0.11126016080379486,1.805647611618042,0.6230979561805725,0.36196717619895935,0.0321471132338047,1.3630361557006836,2.590884208679199,0.6007828712463379,0.14051060378551483,0.3489038646221161,1.0702216625213623,1.4794830083847046,0.39767003059387207,0.20679956674575806,0.015743117779493332,0.2465030550956726,1.7555897235870361,0.06133950874209404,1.101117730140686,0.9891293048858643,0.47916021943092346,0.04654693230986595,1.335697054862976,1.2709628343582153,0.1092357262969017,0.3777872622013092,0.25866177678108215,2.8629610538482666,0.330032616853714,0.30021238327026367,0.14954997599124908,0.5424569845199585,0.07252263277769089,0.15865133702754974,0.40076035261154175,0.7282562851905823,0.3705361783504486,0.015413789078593254,0.015840834006667137,0.4034458100795746,0.02868160977959633,1.3420019149780273,0.036083247512578964,0.8236557245254517,0.7892447710037231,0.12343525141477585,0.07038391381502151,0.06860870867967606,0.6933117508888245,0.0,0.3600417673587799,0.3517952859401703,0.7348923087120056,2.3836183547973633,0.19568277895450592,0.019822144880890846,0.49209439754486084,1.1363734006881714,0.7762866616249084,0.35173341631889343,0.059090349823236465,0.24521274864673615,1.3700393438339233,0.5121893286705017,0.45342862606048584,2.3489906787872314,0.130288764834404,0.9179604053497314,0.23467522859573364,1.2870936393737793,0.18395568430423737,0.896112322807312,0.05169786885380745,0.5849955081939697,0.17520982027053833,0.4322708249092102,0.10064983367919922,0.6949729919433594,0.31241825222969055,0.017296070232987404,0.21149475872516632,0.10829086601734161,0.5270223021507263,0.3509761691093445,0.8720590472221375,0.7077852487564087,1.0009738206863403,0.2758578360080719,0.001055699191056192,0.12185824662446976,0.1356113702058792,0.6326422691345215,0.30826836824417114,0.43483516573905945,0.6391230821609497,0.015828637406229973,0.060418616980314255,0.08130747824907303,0.8263728618621826,0.6869108080863953,1.4351948499679565,1.5345723628997803,0.17672862112522125,0.7611819505691528,0.19866245985031128,0.03643443062901497,0.40735024213790894,0.8617676496505737,0.6442905068397522,0.13291509449481964,0.08961779624223709,0.013482140377163887,0.3748442530632019,0.628272294998169,0.48694804310798645,0.6231419444084167,0.354279100894928,0.8560224175453186,1.8554027080535889,0.018688630312681198,0.558110773563385,0.8572626709938049,1.342378854751587,0.15025082230567932,0.4749850928783417,0.14787939190864563,0.291209876537323,0.6362593173980713,0.2041471004486084,0.07663371413946152,1.1260404586791992,1.0800954103469849,0.12397252023220062,0.1458875834941864,2.1002097129821777,0.22718596458435059,0.9807181358337402,0.8075492978096008,0.09468934684991837,1.3038803339004517,0.36220166087150574,0.1676052212715149,0.39378318190574646,0.08315883576869965,0.19796334207057953,0.3453468382358551,0.08353745192289352,0.7185510396957397,0.5905119180679321,0.17001262307167053,0.02233128249645233,1.3430479764938354,0.42938247323036194,2.469149589538574,0.17807133495807648,0.6416274309158325,0.7143462896347046,0.24247682094573975,0.3711608946323395,1.1266783475875854,0.21057012677192688,0.08259957283735275,0.06458510458469391,0.7159583568572998,0.08617547154426575,0.8249351382255554,0.5276781916618347,0.21359385550022125,1.655901551246643,2.3674702644348145,0.25014927983283997,0.5986981987953186,0.947422206401825,0.15310008823871613,0.009164717979729176]}}}}"
    }
  },
  "min_score": 1,
  "explain": true,
  "_source": {
    "includes": [
      "id",
      "pic_path"
    ],
    "excludes": []
  },
  "sort": [
    {
      "create_time": {
        "order": "desc"
      }
    }
  ],
  "track_total_hits": 2147483647
}

搜索图片

duck

搜索结果

在这里插入图片描述

看到最后了一起薅个羊毛呗~

在这里插入图片描述

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: elasticsearch java api官方文档是官方提供的关于使用elasticsearchJava API的指南和参考手册。它详细介绍了elasticsearch的各种功能、方法和参数,帮助开发人员理解和使用elasticsearchJava API。 官方文档提供了详细的使用示例和代码片段,帮助开发人员快速上手。通过官方文档,开发人员可以了解如何建立elasticsearch客户端连接、创建索引、添加文档、进行搜索和查询等操作。此外,官方文档还介绍了如何使用各种过滤器、聚合操作和排序功能,以及如何进行全文搜索和地理位置搜索。 官方文档也提供了关于如何处理异常和错误的指导,帮助开发人员更好地进行故障排查和处理。此外,官方文档还包含了关于性能调优、集群管理和安全配置等方面的建议和最佳实践。 总之,elasticsearch java api官方文档是一个非常有价值的工具,它为使用Java开发elasticsearch应用程序的开发人员提供了必要的指导和支持。通过阅读官方文档,开发人员可以更好地理解和掌握elasticsearchJava API,提高应用程序的性能和稳定性。 ### 回答2: elasticsearch java API官方文档是elasticsearch官方提供的用于Java开发的API文档。它包含了elasticsearch中所有Java API的详细说明和使用指南,可以帮助开发人员在Java应用程序中使用elasticsearch进行索引、搜索和管理数据。 elasticsearch是一个开源的分布式搜索和分析引擎,它基于Lucene库构建,并提供了一个RESTful API用于与其进行交互。elasticsearch java API官方文档通过提供详细的类和方法的说明,以及示例代码和最佳实践,帮助开发人员快速上手elasticsearch实现各种功能。 在elasticsearch java API官方文档中,开发人员可以了解到如何创建和配置elasticsearch客户端、连接到elasticsearch集群、执行不同类型的搜索、对结果进行排序和过滤、执行聚合操作、进行索引和文档的操作、处理分页和滚动搜索等等。 官方文档还提供了一系列的代码示例,帮助开发人员理解和学习elasticsearch java API的使用。这些示例覆盖了不同的应用场景,如基本搜索、复杂搜索、地理位置搜索、聚合查询等等,使得开发人员能够根据自己的需求,快速上手并进行开发。 总而言之,elasticsearch java API官方文档是elasticsearch官方提供的非常有价值的资源,将帮助开发人员在Java应用程序中有效地使用elasticsearch进行搜索和管理数据。通过阅读官方文档,开发人员能够深入了解elasticsearch的工作原理和各种功能的使用方法,从而更好地构建出强大的搜索应用。 ### 回答3: Elasticsearch Java API官方文档是为了帮助Java开发者使用Elasticsearch搜索引擎而编写的一份指南。这个文档详细介绍了如何在Java应用程序中使用Elasticsearch的各种功能和特性。 该文档首先提供了关于Elasticsearch的简要介绍,包括其核心概念、工作原理和主要用途。然后,它详细描述了如何在Java应用程序中集成和配置Elasticsearch客户端,并提供了使用示例。 接下来,文档介绍了Elasticsearch搜索功能,包括如何构建查询、执行过滤和排序操作以及如何使用聚合框架。它还解释了Elasticsearch中的分析器和分词器是如何工作的,并且给出了一些常见的搜索用例和示例代码。 此外,文档还介绍了Elasticsearch的索引管理和数据操作,包括如何创建索引、映射字段和执行文档的添加、更新和删除等操作。它还介绍了如何使用批量API执行批量操作以提高性能。 最后,文档提供了关于Elasticsearch的聚合和分析的详细信息,包括基本聚合、嵌套聚合和地理空间聚合等。它还解释了如何通过使用Elasticsearch的插件系统扩展其功能。 总体而言,Elasticsearch Java API官方文档提供了丰富的内容和严谨的示例代码,使Java开发者能够快速上手并有效地利用Elasticsearch的强大功能。无论是初学者还是有经验的开发者,都可以从这个文档中获得宝贵的指导和参考。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值