使用Spring訪問Mongodb的方法大全——Spring Data MongoDB查詢指南

1.概述

Spring Data MongoDB 是Spring框架訪問mongodb的神器,借助它可以非常方便的讀寫mongo庫。本文介紹使用Spring Data MongoDB來訪問mongodb數據庫的幾種方法:

  • 使用Query和Criteria類
  • JPA自動生成的查詢方法
  • 使用@Query 注解基于JSON查詢

在開始前,首先需要引入maven依賴

1.1 添加Maven的依賴

如果您想使用Spring Data MongoDB,則需要將以下條目添加到您的pom.xml文件中:

<dependency><groupId>org.springframework.data</groupId><artifactId>spring-data-mongodb</artifactId><version>1.9.6.RELEASE</version>
</dependency>

版本根據需要選擇。

2.文檔查詢

使用Spring Data來查詢MongoDB的最常用方法之一是使用Query和Criteria類 , 它們非常接近本地操作符。

2.1 is查詢

在以下示例中 - 我們正在尋找名為Eric的用戶。

我們來看看我們的數據庫:

[{"_id" : ObjectId("55c0e5e5511f0a164a581907"),"_class" : "org.baeldung.model.User","name" : "Eric","age" : 45},{"_id" : ObjectId("55c0e5e5511f0a164a581908"),"_class" : "org.baeldung.model.User","name" : "Antony","age" : 55}
}]

讓我們看看查詢代碼:

Query query = new Query();
query.addCriteria(Criteria.where("name").is("Eric"));
List<User> users = mongoTemplate.find(query, User.class);

如預期的那樣,這個邏輯返回:

{"_id" : ObjectId("55c0e5e5511f0a164a581907"),"_class" : "org.baeldung.model.User","name" : "Eric","age" : 45
}

2.2 正則查詢

正則表達式是一個更靈活和強大的查詢類型。這使用了一個使用MongoDB $ regex的標準,該標準返回適用于這個字段的這個正則表達式的所有記錄。

它的作用類似于startingWith,endingWith操作 - 讓我們來看一個例子。

尋找名稱以A開頭的所有用戶,這是數據庫的狀態:

[{"_id" : ObjectId("55c0e5e5511f0a164a581907"),"_class" : "org.baeldung.model.User","name" : "Eric","age" : 45},{"_id" : ObjectId("55c0e5e5511f0a164a581908"),"_class" : "org.baeldung.model.User","name" : "Antony","age" : 33},{"_id" : ObjectId("55c0e5e5511f0a164a581909"),"_class" : "org.baeldung.model.User","name" : "Alice","age" : 35}
]

我們來創建查詢:

Query query = new Query();
query.addCriteria(Criteria.where("name").regex("^A"));
List<User> users = mongoTemplate.find(query,User.class);

這運行并返回2條記錄:

[{"_id" : ObjectId("55c0e5e5511f0a164a581908"),"_class" : "org.baeldung.model.User","name" : "Antony","age" : 33},{"_id" : ObjectId("55c0e5e5511f0a164a581909"),"_class" : "org.baeldung.model.User","name" : "Alice","age" : 35}
]

下面是另一個簡單的例子,這次查找名稱以c結尾的所有用戶:

Query query = new Query();
query.addCriteria(Criteria.where("name").regex("c$"));
List<User> users = mongoTemplate.find(query, User.class);

所以結果是:

{"_id" : ObjectId("55c0e5e5511f0a164a581907"),"_class" : "org.baeldung.model.User","name" : "Eric","age" : 45
}

2.3 LT和GT

$ lt(小于)運算符和$ gt(大于)。

讓我們快速看一個例子 - 我們正在尋找年齡在20歲到50歲之間的所有用戶。

數據庫是:

[{"_id" : ObjectId("55c0e5e5511f0a164a581907"),"_class" : "org.baeldung.model.User","name" : "Eric","age" : 45},{"_id" : ObjectId("55c0e5e5511f0a164a581908"),"_class" : "org.baeldung.model.User","name" : "Antony","age" : 55}
}

構造查詢:

Query query = new Query();
query.addCriteria(Criteria.where("age").lt(50).gt(20));
List<User> users = mongoTemplate.find(query,User.class);

結果 - 年齡大于20且小于50的所有用戶:

{"_id" : ObjectId("55c0e5e5511f0a164a581907"),"_class" : "org.baeldung.model.User","name" : "Eric","age" : 45
}

2.4 結果排序

Sort用于指定結果的排序順序。

首先 - 這里是現有的數據:

[{"_id" : ObjectId("55c0e5e5511f0a164a581907"),"_class" : "org.baeldung.model.User","name" : "Eric","age" : 45},{"_id" : ObjectId("55c0e5e5511f0a164a581908"),"_class" : "org.baeldung.model.User","name" : "Antony","age" : 33},{"_id" : ObjectId("55c0e5e5511f0a164a581909"),"_class" : "org.baeldung.model.User","name" : "Alice","age" : 35}
]

執行排序后:

Query query = new Query();
query.with(new Sort(Sort.Direction.ASC, "age"));
List<User> users = mongoTemplate.find(query,User.class);

這是查詢的結果 - 很好地按年齡排序:

[{"_id" : ObjectId("55c0e5e5511f0a164a581908"),"_class" : "org.baeldung.model.User","name" : "Antony","age" : 33},{"_id" : ObjectId("55c0e5e5511f0a164a581909"),"_class" : "org.baeldung.model.User","name" : "Alice","age" : 35},{"_id" : ObjectId("55c0e5e5511f0a164a581907"),"_class" : "org.baeldung.model.User","name" : "Eric","age" : 45}
]

2.5 分頁

我們來看一個使用分頁的簡單例子。

這是數據庫的狀態:

[{"_id" : ObjectId("55c0e5e5511f0a164a581907"),"_class" : "org.baeldung.model.User","name" : "Eric","age" : 45},{"_id" : ObjectId("55c0e5e5511f0a164a581908"),"_class" : "org.baeldung.model.User","name" : "Antony","age" : 33},{"_id" : ObjectId("55c0e5e5511f0a164a581909"),"_class" : "org.baeldung.model.User","name" : "Alice","age" : 35}
]

現在,查詢邏輯,只需要一個大小為2的頁面:

final Pageable pageableRequest = new PageRequest(0, 2);
Query query = new Query();
query.with(pageableRequest);

結果 :

[{"_id" : ObjectId("55c0e5e5511f0a164a581907"),"_class" : "org.baeldung.model.User","name" : "Eric","age" : 45},{"_id" : ObjectId("55c0e5e5511f0a164a581908"),"_class" : "org.baeldung.model.User","name" : "Antony","age" : 33}
]

為了探索這個API的全部細節,這里是Query和Criteria類的文檔。

3.生成的查詢方法(Generated Query Methods)

生成查詢方法是JPA的一個特性,在Spring Data Mongodb里也可以使用。

要做到2里功能,只需要在接口上聲明方法即可,

public interface UserRepository extends MongoRepository<User, String>, QueryDslPredicateExecutor<User> {...
}

3.1 FindByX

我們將通過探索findBy類型的查詢來簡單地開始 - 在這種情況下,通過名稱查找:

List<User> findByName(String name);

與上一節相同 2.1 - 查詢將具有相同的結果,查找具有給定名稱的所有用戶:

List<User> users = userRepository.findByName("Eric");

3.2 StartingWith and endingWith.

下面是操作過程的一個簡單例子:

List<User> findByNameStartingWith(String regexp);List<User> findByNameEndingWith(String regexp);

實際使用這個例子當然會非常簡單:

List<User> users = userRepository.findByNameStartingWith("A");
List<User> users = userRepository.findByNameEndingWith("c");

結果是完全一樣的。

3.3 Between

類似于2.3,這將返回年齡在ageGT和ageLT之間的所有用戶:

List<User> findByAgeBetween(int ageGT, int ageLT);
List<User> users = userRepository.findByAgeBetween(20, 50);

3.4 Like和OrderBy

讓我們來看看這個更高級的示例 - 為生成的查詢組合兩種類型的修飾符。

我們將要查找名稱中包含字母A的所有用戶,我們也將按年齡順序排列結果:

List<User> users = userRepository.findByNameLikeOrderByAgeAsc("A");

結果:

[{"_id" : ObjectId("55c0e5e5511f0a164a581908"),"_class" : "org.baeldung.model.User","name" : "Antony","age" : 33},{"_id" : ObjectId("55c0e5e5511f0a164a581909"),"_class" : "org.baeldung.model.User","name" : "Alice","age" : 35}
]

4. JSON查詢方法

如果我們無法用方法名稱或條件來表示查詢,那么我們可以做更低層次的事情 - 使用@Query注解。

通過這個注解,我們可以指定一個原始查詢 - 作為一個Mongo JSON查詢字符串。

4.1 FindBy

讓我們先從簡單的,看看我們是如何將是一個通過查找類型的方法第一:

@Query("{ 'name' : ?0 }")
List<User> findUsersByName(String name);

這個方法應該按名稱返回用戶 - 占位符?0引用方法的第一個參數。

4.2 $regex

讓我們來看一個正則表達式驅動的查詢 - 這當然會產生與2.2和3.2相同的結果:

@Query("{ 'name' : { $regex: ?0 } }")
List<User> findUsersByRegexpName(String regexp);

用法也完全一樣:

List<User> users = userRepository.findUsersByRegexpName("^A");
List<User> users = userRepository.findUsersByRegexpName("c$");

4.3. $ lt和$ gt

現在我們來實現lt和gt查詢:

@Query("{ 'age' : { $gt: ?0, $lt: ?1 } }")
List<User> findUsersByAgeBetween(int ageGT, int ageLT);

5. 結論

在本文中,我們探討了使用Spring Data MongoDB進行查詢的常用方法。

本文示例可以從 spring-data-mongodb這里下載。

本文參考A Guide to Queries in Spring Data MongoDB


作者:Jadepeng
出處:jqpeng的技術記事本--http://www.cnblogs.com/xiaoqi
您的支持是對博主最大的鼓勵,感謝您的認真閱讀。
本文版權歸作者所有,歡迎轉載,但未經作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文連接,否則保留追究法律責任的權利。

轉載于:https://www.cnblogs.com/xiaoqi/p/queries-in-spring-data-mongodb.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/281550.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/281550.shtml
英文地址,請注明出處:http://en.pswp.cn/news/281550.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

mysqldump導出備份數據庫報Table ‘performance_schema.session_variables‘ doesn‘t exist

今天在bash進行本地數據庫往云端數據庫導數據的時候&#xff0c;在本地導出.sql文件這第一步就出現了錯誤問題&#xff0c;導出sql文件的命令&#xff1a; 1 mysqldump -u 用戶名 -p 數據庫名 > xxx.sql 在做這一步將數據導出的時候報了這么一個錯誤&#xff0c; 1 mysqldu…

在Identity框架中使用RoleBasedAuthorization

本文將介紹在 Identity 框架中如何使用 Sang.AspNetCore.RoleBasedAuthorization[1] 庫。核心介紹Identity 和 jwt 的基本配置我們在這里不再贅述&#xff0c;可以參考最后的項目樣例。核心的代碼主要為 IRolePermission 的實現。internal class MyRolePermission : IRolePermi…

2016年印度公有云服務市場將達13億美元

根據IT咨詢公司Gartner最新調查數據顯示&#xff0c;2016年印度公有云服務市場預計將增長35.9%&#xff0c;達到13億美元。 增長最快的是云系統基礎設施即服務&#xff08;IaaS&#xff09;&#xff0c;2016年預計將增長45.5%&#xff1b;其次是平臺即服務&#xff08;PaaS&…

PAT 1042. 字符統計

1042. 字符統計 請編寫程序&#xff0c;找出一段給定文字中出現最頻繁的那個英文字母。 輸入格式&#xff1a; 輸入在一行中給出一個長度不超過1000的字符串。字符串由ASCII碼表中任意可見字符及空格組成&#xff0c;至少包含1個英文字母&#xff0c;以回車結束&#xff08;回車…

Magicodes.IE 2.7.0-beta發布

2.7.0-beta2022.10.27使用SixLabors.ImageSharp替代System.Drawing&#xff0c;感謝linch90 &#xff08;見pr#454&#xff09;2.6.92022.10.26fix: 動態數據源導出到多個sheet的問題 &#xff08;見#449&#xff09;2.6.82022.10.18Excel模板導出添加API&#xff0c;以支持通過…

光伏逆變器“領跑”:不止于技術

從無到有&#xff0c;從效率比拼到突破99%&#xff0c;在跟進速度上沒話說的國內光伏逆變器企業難免深陷“價格戰”、同質化的泥潭。隨著“領跑者”計劃躍居光伏主流&#xff0c;嗅到市場紅利的企業再次蜂擁而至。 目前&#xff0c;鑒衡認證發布的第一批光伏并網逆變器“領跑者…

Ubuntu 18.04上Qmmp安裝教程

Qmmp&#xff0c;一個開源的基于Qt的多媒體播放器。它具有多種音頻文件格式支持&#xff0c;DSP效果&#xff0c;視覺效果;輸出系統支持&#xff08;OSS4&#xff08;FreeBSD&#xff09;&#xff0c;ALSA&#xff08;Linux&#xff09;&#xff0c;Pulse Audio&#xff0c;JAC…

android自動跑馬燈,Android-最強跑馬燈

Android--最強跑馬燈Android 跑馬燈已經有很多版本&#xff0c;從最基本的TextView&#xff0c;到重寫TextView使TextView取消焦點限制&#xff0c;還有重寫TextView利用ScrollTo方法寫的&#xff0c;基本都能滿足一般需要。然而在使用過程中&#xff0c;發現一些意外---有時會…

python:軟件目錄結構規范

為什么要設計好目錄結構&#xff1f; “設計項目目錄結構”&#xff0c;就和“代碼編碼風格”一樣&#xff0c;屬于個人風格問題。對于這種風格上的規范&#xff0c;一直都存在兩種態度&#xff1a; 1.一種認為&#xff0c;這種個人風格問題“無關緊要”。理由是能讓程序work就…

開啟智能生活新時代 河北省智慧社區建設從各個擊破

智慧社區作為智慧城市的重要組成部分&#xff0c;是城市智慧落地的觸點&#xff0c;是城市管理、政務服務和市場服務的載體。隨著智慧城市的推廣以及新一代技術的普及&#xff0c;智慧社區的項目必將迎來新一輪的快速發展。2016年智慧社區成為企業業務落地的承載點&#xff0c;…

C# WPF 表格控件的前后臺數據交互?

概述GridControl控件使用我們已經進行了實例講解&#xff0c;這節內容我們列舉一個特殊的應用場景&#xff1a;表格中有一列CheckBox&#xff0c;默認都處于勾選狀態&#xff0c;當用戶通過界面操作后&#xff0c;我們要確保用戶至少選擇了一項&#xff0c;相當于一次數據驗證&…

Java(C#)基礎差異-語法

1、long類型 Java long類型&#xff0c;若賦值大于int型的最大值&#xff0c;或小于int型的最小值&#xff0c;則需要在數字后加L或者l&#xff0c;表示該數值為長整數&#xff0c;如long num2147483650L。 舉例如下&#xff1a; public static void main(String[] args) {/** …

android防止左向右滑出程序,Android——ViewPager禁止左右滑動的實現

目錄1 背景用ViewPagerBottomNavigationView多個Fragment快速搭建的頁面切換架構&#xff0c;一個有四個頁面&#xff0c;因為測試需要&#xff0c;需要屏蔽掉中間的兩個&#xff0c;做法是&#xff1a;設置不可點擊選擇&#xff1a;xml布局文件中&#xff0c;BottomNavigation…

Yii2 的快速配置 api 服務 yii2-fast-api

yii2-fast-api yii2-fast-api是一個Yii2框架的擴展&#xff0c;用于配置完善Yii2&#xff0c;以實現api的快速開發。 此擴展默認的場景是APP的后端接口開發&#xff0c;因此偏向于實用主義&#xff0c;并未完全采用restfull的標準&#xff0c;方便前端開發處理接口數據以及各種…

.NET6打包部署到Windows Service

1.安裝Nuget包安裝以下nuget包支持windows service<PackageReference Include"Microsoft.AspNetCore.Hosting.WindowsServices" Version"6.0.10" /> <PackageReference Include"Microsoft.Extensions.Hosting.WindowsServices" Version…

傳統家電在智能家居變革的五大優勢

而在眾多向智能家居領域轉型變革的企業中&#xff0c;看似落后的傳統家電企業&#xff0c;卻占據著一定的優勢。 產品優勢 傳統家電企業在產品上的優勢主要體現在企業擁有產品本身的設計、技術、生產、制造和營銷渠道&#xff0c;其產品不論是從外觀設計、零件制造還是零件組裝…

《Apache Kafka實戰》讀書筆記-調優Kafka集群

《Apache Kafka實戰》讀書筆記-調優Kafka集群 作者&#xff1a;尹正杰 版權聲明&#xff1a;原創作品&#xff0c;謝絕轉載&#xff01;否則將追究法律責任。 一.確定調優目標 1>.常見的非功能性要求 一.性能&#xff08;performance&#xff09;最重要的非功能性需求之一。…

android emoji unicode編碼表,unicode編碼

unicode編碼app是一款字符查找客戶端應用&#xff0c;通過unicode編碼可以方便尋找特定字符&#xff0c;查看字符表情詳細的描述&#xff0c;并且利用unicode編碼就可以快捷復制任意unicode編碼&#xff0c;提高開發效率&#xff0c;非常的實用&#xff0c;快來下載unicode編碼…

物聯網商機誘人 芯片商大力搭建生態系統

應用需求變化多端的物聯網&#xff0c;雖具備龐大的發展潛力及應用商機&#xff0c;但由于市場過于分散&#xff0c;幾乎沒有殺手應用可言&#xff0c;因此對有意耕耘相關市場的半導體業者而言&#xff0c;如何借力使力&#xff0c;尋找盟友共同搭建出的生態系統&#xff0c;遂…

ASP.NET Core 6框架揭秘實例演示[30]:利用路由開發REST API

借助路由系統提供的請求URL模式與對應終結點之間的映射關系&#xff0c;我們可以將具有相同URL模式的請求分發給與之匹配的終結點進行處理。ASP.NET的路由是通過EndpointRoutingMiddleware和EndpointMiddleware這兩個中間件協作完成的&#xff0c;它們在ASP.NET平臺上具有舉足輕…