日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網為廣大站長提供免費收錄網站服務,提交前請做好本站友鏈:【 網站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

本文介紹了Spring data MongoDB:在多個字段上搜索Like的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!

問題描述

我有一個MongoDB集合,其中包含帶有兩個字段的User對象:FirstName和LastName。我需要一個只接受一個字符串(表示用戶全名)的查詢來進行findLike搜索。

問題與此相同question但我不知道如何使用MongoTemplate或@Query批注在Spring數據中轉換MongoDB存儲庫查詢

編輯:
使用項目操作員,我必須指定我想要包括在階段的所有領域。更好的解決方案可能是使用AddFields運算符:
我發現的一個類似的問題是:
https://stackoverflow.com/a/40812293/6545142

如何將$AddFields運算符與MongoTemplate一起使用?

推薦答案

您可以使用$expr(3.6mongo版本運算符)在常規查詢中僅使用精確匹配的聚合函數。

Spring@Query代碼

@Query("{$expr:{$eq:[{$concat:["$Firstname","$Lastname"]}, ?0]}}")
ReturnType MethodName(ArgType arg);

對于Find Like搜索或精確搜索,您必須在較低版本中使用通過Mongo模板聚合。

AggregationOperation project = Aggregation.project().and(StringOperators.Concat.valueOf("Firstname").concatValueOf("Lastname")).as("newField");

For Like Matches

AggregationOperation match = Aggregation.match(Criteria.where("newField").regex(val));

完全匹配

AggregationOperation match = Aggregation.match(Criteria.where("newField").is(val));

代碼的其余部分

 Aggregation aggregation = Aggregation.newAggregation(project, match);
 List<BasicDBObject> basicDBObject =  mongoTemplate.aggregate(aggregation, colname, BasicDBObject.class).getMappedResults();

這篇關于Spring data MongoDB:在多個字段上搜索Like的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,

分享到:
標簽:Data MongoDB Spring 多個 字段
用戶無頭像

網友整理

注冊時間:

網站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網站吧!
最新入駐小程序

數獨大挑戰2018-06-03

數獨一種數學游戲,玩家需要根據9

答題星2018-06-03

您可以通過答題星輕松地創建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學四六

運動步數有氧達人2018-06-03

記錄運動步數,積累氧氣值。還可偷

每日養生app2018-06-03

每日養生,天天健康

體育訓練成績評定2018-06-03

通用課目體育訓練成績評定