Spring Data MongoDB 使用
本文为博主原创,转载请注明出处:
Spring Data MongoDB 是 Spring Data 系列的一部分,它提供了与 MongoDB 的集成和操作支持,类似于 JPA 对关系型数据库的支持。通过使用 Spring Data MongoDB,您可以使用类似于 JPA 的 Repository 接口、自动映射功能以及其他便利特性来访问和操作 MongoDB 数据库。
1.Spring Data MongoDB接入
1.1添加依赖:
在项目的构建文件(如 Maven 的 pom.xml 或 Gradle 的 build.gradle)中添加 Spring Data MongoDB 的依赖项。例如,在 Maven 中添加以下依赖项:
<dependencies>
<!-- 其他依赖 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-mongodb</artifactId>
</dependency>
</dependencies>
1.2 创建实体类:
使用 MongoDB 的注解来定义实体类,并将其映射到 MongoDB 的集合(collection)。注解包括 @Document、@Field、@Id 等。
import org.springframework.data.mongodb.core.mapping.Document;
import org.springframework.data.annotation.Id; @Document(collection = "users")
public class User { @Id
private String id; @Field("name")
private String name; // getter and setter methods
}
1.3创建 Repository 接口:
创建一个继承自 MongoRepository(或其他 Spring Data MongoDB 提供的 Repository 接口)的接口,用于访问和操作实体类对应的 MongoDB 数据
import org.springframework.data.mongodb.repository.MongoRepository;
public interface UserRepository extends MongoRepository<User, String> {
// 可根据需要添加自定义查询方法
}
1.4配置 MongoDB 连接信息:
在 Spring Boot 的配置文件中,配置 MongoDB 的连接信息,例如数据库名称、主机地址、端口等。
spring.data.mongodb.host=localhost
spring.data.mongodb.port=27017
spring.data.mongodb.database=mydatabase
- 使用 Repository 进行操作:在需要使用 MongoDB 操作的地方,通过注入 Repository 接口对象来调用相应的方法。
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service; @Service
public class UserService { private final UserRepository userRepository; @Autowired
public UserService(UserRepository userRepository) {
this.userRepository = userRepository;
} public User saveUser(User user) {
return userRepository.save(user);
} public User getUserById(String id) {
return userRepository.findById(id).orElse(null);
} // 其他操作方法
}
上述示例是一个简单的使用 JPA 和 MongoDB 的流程。它包括创建实体类、定义 Repository 接口、配置 MongoDB 的连接信息和使用 Repository 进行操作。这样可以使用 Spring Data MongoDB 结合 JPA 和 MongoDB 进行开发,并享受到 Spring Data 提供的便利特性。
2.Spring Data MongoDB 自定义方法解析使用
在 UserRepository 中定义使用的方法非常简单。Spring Data MongoDB 提供了一套命名规则,它根据方法名自动解析和生成查询语句。您可以按照规则给方法命名,而不需要编写具体的查询语句。
以下是一些常见的方法命名规则及其解析方式:
根据属性查询:
findBy<PropertyName>:根据属性名称进行查询,例如findByName(String name)。findBy<PropertyName>And<OtherProperty>:根据多个属性进行查询,并通过 "And" 连接,例如findByNameAndAge(String name, int age)。
按条件查询:
findBy<PropertyName>Equals:根据属性的精确匹配进行查询,例如findByNameEquals(String name)。findBy<PropertyName>In:根据属性值在给定集合中的条件进行查询,例如findByAgeIn(Collection<Integer> ages)。
模糊查询:
findBy<PropertyName>Like:根据属性值进行模糊查询,例如findByNameLike(String keyword)。
除了以上示例,还有更多可用的方法命名规则,可以根据具体需求查阅 Spring Data MongoDB 文档以获得更全面的了解。
注意事项:
- 方法名称必须遵循命名规则,否则可能会导致查询失败。
- 方法参数的数量和类型必须与属性的类型和数量匹配。
- 在使用一些特殊操作时,如模糊查询、集合查询等,可以使用
Like、In等关键字来指定更复杂的条件。
以下是一个简单的示例:
import org.springframework.data.mongodb.repository.MongoRepository;
import java.util.List; public interface UserRepository extends MongoRepository<User, String> {
List<User> findByName(String name);
List<User> findByAgeGreaterThan(int age);
List<User> findByEmailNotNull();
List<User> findByAgeIn(List<Integer> ages);
List<User> findByNameLike(String keyword);
}
在上述示例中,UserRepository 定义了五个查询方法:根据名称查询用户、根据年龄大于给定值查询用户、查询邮箱不为 null 的用户、根据年龄在给定集合中查询用户以及根据名称进行模糊查询。这些方法会根据方法名自动解析为相应的查询条件,并返回符合条件的用户列表。
请注意,在实际使用过程中,可能需要处理一些特定的查询场景或复杂的条件,可能需要编写自定义的查询语句。Spring Data MongoDB 提供了注解和其他方式来支持自定义查询,以满足更复杂的需求。
3.自定义查询语句
在 Spring Data MongoDB 中,可以使用自定义的查询语句来满足特定的查询需求。以下是两种常用的方式来实现自定义查询:
3.1使用 @Query 注解:
- 在需要进行自定义查询的方法上添加
@Query注解,并提供相应的查询语句。 - 在查询语句中使用命名参数(例如
:paramName)来引用方法参数。 - 如果有多个参数,可以通过索引位置(例如
?0、?1)引用它们。
示例:
import org.springframework.data.mongodb.repository.MongoRepository;
import org.springframework.data.mongodb.repository.Query;
import java.util.List; public interface UserRepository extends MongoRepository<User, String> {
@Query("{ 'name' : ?0 }")
List<User> findByName(String name); @Query("{ 'age' : { $gt: ?0 }, 'email' : { $ne: null } }")
List<User> findByAgeGreaterThanAndEmailNotNull(int age);
}
在上述示例中,使用了 @Query 注解来自定义查询语句。通过 ?0 引用了方法参数,并根据属性条件进行查询。
3.2使用 Criteria API:
- 创建一个
Criteria对象,并使用其提供的方法来构建查询条件。 - 将
Criteria对象传递给MongoTemplate的find方法进行查询。
- 创建一个
示例:
import org.springframework.data.mongodb.core.MongoTemplate;
import org.springframework.data.mongodb.core.query.Criteria;
import org.springframework.data.mongodb.core.query.Query;
import java.util.List; public class UserRepositoryImpl implements UserRepositoryCustom { private final MongoTemplate mongoTemplate; public UserRepositoryImpl(MongoTemplate mongoTemplate) {
this.mongoTemplate = mongoTemplate;
} @Override
public List<User> findByAgeGreaterThanAndEmailNotNull(int age) {
Criteria criteria = Criteria.where("age").gt(age).and("email").ne(null);
Query query = new Query(criteria);
return mongoTemplate.find(query, User.class);
}
}
在上述示例中,UserRepositoryImpl 实现了 UserRepositoryCustom 接口,并使用 MongoTemplate 和 Criteria API 来自定义查询方法。在 findByAgeGreaterThanAndEmailNotNull 方法中,创建了一个 Criteria 对象,并指定年龄大于给定值且邮箱不为空的条件,然后将其传递给 Query 对象并执行查询。
Spring Data MongoDB 使用的更多相关文章
- spring data mongodb 配置遇到的几个问题
一. mongodb 2.2版本以上的配置 spring.data.mongodb.uri = mongodb://newlook:newlook@192.168.0.109:27017/admin ...
- spring data mongodb中,如果对象中的属性不想加入到数据库字段中
spring data mongodb中,如果对象中的属性不想加入到数据库字段中,可加@Transient注解,声明为透明属性 spring data mongodb 官网帮助文档 http://ww ...
- Spring Data MongoDB example with Spring MVC 3.2
Spring Data MongoDB example with Spring MVC 3.2 Here is another example web application built with S ...
- 使用Spring访问Mongodb的方法大全——Spring Data MongoDB查询指南
1.概述 Spring Data MongoDB 是Spring框架访问mongodb的神器,借助它可以非常方便的读写mongo库.本文介绍使用Spring Data MongoDB来访问mongod ...
- Spring data mongodb 聚合,投射,内嵌数组文档分页.
尽量别直接用 DBObject ,Spring data mongodb 的api 本来就没什么多大用处,如果还直接用 DBObject 那么还需要自己去解析结果,说动做个对象映射,累不累 Spri ...
- JAVA 处理 Spring data mongodb 时区问题
Spring data mongodb 查询出结果的时候会自动 + 8小时,所以我们看起来结果是对的 但是我们查询的时候,并不会自动 + 8小时,需要自己处理 解决方法 1 @JsonFormat ...
- Spring data mongodb ObjectId ,根据id日期条件查询,省略@CreatedDate注解
先看看ObjectId 的json 结构,非常丰富,这里有唯一机器码,日期,时间戳等等,所以强烈建议ID 使用 ObjectId 类型,并且自带索引 Spring data mongodb 注解 @C ...
- Spring data mongodb @CreatedBy@LastModifiedBy@CreatedBy@LastModifiedBy SpringSecurityAuditorAware,只记录用户名
要在Spring data mongodb 中使用@CreatedBy@LastModifiedBy@CreatedBy@LastModifiedBy 这四个注解 必须实现 SpringSecuri ...
- Spring Data MongoDB 三:基本文档查询(Query、BasicQuery)(一)
一.简单介绍 Spring Data MongoDB提供了org.springframework.data.mongodb.core.MongoTemplate对MongoDB的CRUD的操作,上一 ...
- Introduction to Spring Data MongoDB
Introduction to Spring Data MongoDB I just announced the new Spring 5 modules in REST With Spring: & ...
随机推荐
- ChatGPT在工业领域的研究与应用探索-数据与工况认知
1. ChatGPT发展现状... 2 2. ChatGPT如何与工业相结合... 2 3. ChatGPT在工业领域的研究与应用... 3 1. ChatGPT发展 ...
- python 编程规范有哪些?
Python 编程规范主要包括代码布局.命名规范.注释规范.函数编写规范等多个方面,下面给出一些常见的编程规范及其示例代码. 1. 代码布局规范 代码布局规范主要是指代码的缩进.行宽.空行.换行等方面 ...
- Driver8833电机驱动模块的使用(STM32为主控)
一.硬件 STM32C8T6.STLINK下载器 Driver8833:TI公司的DRV8833是双桥马达驱动器解决方案,包括有两个H桥驱动器,可驱动两个DC电刷马达,或一个步进马达, 螺线管和其它电 ...
- 2022-06-28:以下golang代码输出什么?A:true;B:false;C:panic;D:编译失败。 package main import “fmt“ func main() {
2022-06-28:以下golang代码输出什么?A:true:B:false:C:panic:D:编译失败. package main import "fmt" func ma ...
- 2022-06-01:给定一个数组arr,可能有正、有负、有0,无序。 只能挑选两个数字,想尽量让两个数字加起来的绝对值尽量小。 返回可能的最小的值。
2022-06-01:给定一个数组arr,可能有正.有负.有0,无序. 只能挑选两个数字,想尽量让两个数字加起来的绝对值尽量小. 返回可能的最小的值. 答案2022-06-01: 排序,双指针. 代码 ...
- 2022-04-13:给你一个下标从 0 开始包含 n 个正整数的数组 arr ,和一个正整数 k 。 如果对于每个满足 k <= i <= n-1 的下标 i ,都有 arr[i-k] <= arr
2022-04-13:给你一个下标从 0 开始包含 n 个正整数的数组 arr ,和一个正整数 k . 如果对于每个满足 k <= i <= n-1 的下标 i ,都有 arr[i-k] ...
- celery笔记二之建立celery项目、配置及几种加载方式
本文首发于公众号:Hunter后端 原文链接:celery笔记二之建立celery项目.配置及几种加载方式 接下来我们创建一个 celery 项目,文件夹及目录如下: proj/__init__.py ...
- Basic Pentesting
来自tryhackme的 Basic Pentesting 开靶场IP:10.10.227.255 # nmap 端口扫描 PORT STATE SERVICE VERSION 22/tcp open ...
- 聊聊Cola-StateMachine轻量级状态机的实现
背景 在分析Seata的saga模式实现时,实在是被其复杂的 json 状态语言定义文件劝退,我是有点没想明白为啥要用这么来实现状态机:盲猜可能是基于可视化的状态机设计器来定制化流程,更方便快捷且上手 ...
- 罕见的技术:MSIL的机器码简析
前言 一般的只有最终的汇编代码才有机器码表示,然一个偶然的机会发现,MSIL(Microsoft intermediate language)作为一个中间语言表示,居然也有机器码,其实这也难怪,计算机 ...