SpringData MongoDB

本文涉及的产品
云数据库 MongoDB,独享型 2核8GB
推荐场景:
构建全方位客户视图
简介: SpringData MongoDB

1 SpringData MongoDB简介

MongoDB是一个跨平台的,面向文档的数据库,是非关系数据库当中功能最丰富,最像关系数据库的产品。它支持的数据结构非常松散,是类似 JSON 的一种格式,因此可以存储比较复杂的数据类型。

MongoDB主要由文档(document)、集合(collection)、数据库(database)三部分组成

  • 文档(document)就相当于关系数据库中的一行记录
  • 多个文档组成一个集合(collection),相当于关系数据库的表
  • 多个集合组织在一起,就是数据库(database),一个 MongoDB 实例支持多个数据库

SpringData MongoDB是SpringData技术封装了mongodb-driver技术之后的产物,它可以用更加简单的方式操作MongoDB。

2 MongoDB环境搭建

2.1 解压

上传文件到服务器,然后将其解压到/usr/local下

[root@localhost src]# tar -zxvf mongodb-linux-x86_64-rhel70-4.0.10.tgz -C /usr/local/

2.2 创建需要的目录

进入软件的安装目录下,创建数据存储和日志存储目录

[root@localhost src]# cd /usr/local/mongodb-linux-x86_64-rhel70-4.0.10/
[root@localhost mongodb-linux-x86_64-rhel70-4.0.10]# mkdir data
[root@localhost mongodb-linux-x86_64-rhel70-4.0.10]# touch log

2.3 创建配置文件

进入bin目录,创建mongodb的配置文件mongo.conf ,文件内容如下:

dbpath=/usr/local/mongodb-linux-x86_64-rhel70-4.0.10/data
logpath=/usr/local/mongodb-linux-x86_64-rhel70-4.0.10/log
bind_ip=0.0.0.0
port=27017
fork=true

2.4 启动mongodb

使用./mongod -f mongo.conf 启动服务,见到类似如下提示,证明启动成功

[root@localhost bin]# ./mongod -f mongo.conf 
about to fork child process, waiting until server is ready for connections.
forked process: 25781
child process started successfully, parent exiting

3 SpringData MongoDB入门案例

3.1目标

通过SpringData技术向Mongodb数据库存储一条数据

3.2 创建工程,引入坐标

<dependencies>
    <dependency>
        <groupId>org.springframework.data</groupId>
        <artifactId>spring-data-mongodb</artifactId>
        <version>2.1.8.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>4.12</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-test</artifactId>
        <version>5.1.6.RELEASE</version>
    </dependency>
</dependencies>

3.3 创建配置文件

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"             
       xmlns:p="http://www.springframework.org/schema/p"
       xmlns:mongo="http://www.springframework.org/schema/data/mongo"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
               http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
               http://www.springframework.org/schema/data/mongo
               http://www.springframework.org/schema/data/mongo/spring-mongo.xsd">
    <!--包扫描-->
    <mongo:repositories base-package="net.csdn"></mongo:repositories>
    <!-- spring连接mongodb数据库的配置 -->
    <mongo:mongo-client host="192.168.106.128" port="27017" id="mongo">
        <mongo:client-options write-concern="SAFE" />
    </mongo:mongo-client>
    <mongo:db-factory id="mongoDbFactory" dbname="oldlu" mongo-ref="mongo" />
    <!--mongoTemplate-->
    <bean id="mongoTemplate" class="org.springframework.data.mongodb.core.MongoTemplate">
        <constructor-arg name="mongoDbFactory" ref="mongoDbFactory" />
    </bean>
</beans>

3.4 创建实体类

@Document(collection = "article")//通过collection参数指定当前实体类对应的文档
public class Article {
    @Id
    private Integer id;
    @Field("title")//给映射存储到 mongodb 的字段取别名
    private String title;
    private String Content;
  //省略set get  toString方法
}

3.5 自定义dao接口

//自定义dao接口继承MongoRepository<实体类型,主键类型>
public interface ArticleDao extends MongoRepository<Article, Integer> {}

3.6 测试

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("classpath:applicationContext.xml")
public class ArticleDaoTest {
    @Autowired
    private ArticleDao articleDao;
    //保存
    @Test
    public void testSave() {
        Article article = new Article();
        article.setId(1);
        article.setTitle("程序员");
        article.setContent("程序员很低调");
        article.setHits(100);
        articleDao.save(article);
    }
}

4 SpringData MongoDB实现CRUD操作

4.1 增删改

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("classpath:applicationContext.xml")
public class ArticleDaoTest {
    @Autowired
    private ArticleDao articleDao;
    //保存
    @Test
    public void testSave() {
        Article article = new Article();
        article.setId(1);
        article.setTitle("程序员");
        article.setContent("程序员很低调");
        article.setHits(100);
        articleDao.save(article);
    }
    //修改
    @Test
    public void testUpdate() {
        Article article = new Article();
        article.setId(1);
        article.setTitle("程序员1");
        article.setContent("程序员很低调1");
        article.setHits(1000);
        articleDao.save(article);
    }
    //删除
    @Test
    public void testDelete() {
        articleDao.deleteById(1);
    }
}

4.2 简单查询

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("classpath:applicationContext.xml")
public class ArticleDaoTest {
    @Autowired
    private ArticleDao articleDao;
    //查询所有
    @Test
    public void testFindAll() {
        List<Article> articles = articleDao.findAll();
        for (Article article : articles) {
            System.out.println(article);
        }
    }
    //根据主键查询
    @Test
    public void testFindByid() {
        Optional<Article> optional = articleDao.findById(1);
        System.out.println(optional.get());
    }
    //排序分页查询
    @Test
    public void testFindAllWithPage() {
        //按照hits倒序排列
        Sort sort = Sort.by(Sort.Order.desc("hits"));
        //从0开始查询,查10条
        Pageable pageable = PageRequest.of(0,10,sort);
        Page<Article> page = articleDao.findAll(pageable);
        for (Article article : page.getContent()) {
            System.out.println(article);
        }
    }
}

4.3 命名规则查询

定义接口

public interface ArticleDao extends MongoRepository<Article, Integer> {
    //根据标题查询
    List<Article> findByTitleLike(String title);
    //根据标题或内容查询
    List<Article> findByHitsGreaterThan(Integer hits);
}
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("classpath:applicationContext.xml")
public class ArticleDaoTest {
    @Autowired
    private ArticleDao articleDao;
    @Test
    public void testFindByTitle() {
        Iterable<Article> articles = articleDao.findByTitleLike("程序员");
        for (Article article : articles) {
            System.out.println(article);
        }
    }
    @Test
    public void testFindByHitsGreaterThan() {
        Iterable<Article> articles = articleDao.findByHitsGreaterThan(110);
        for (Article article : articles) {
            System.out.println(article);
        }
    }
}
相关实践学习
MongoDB数据库入门
MongoDB数据库入门实验。
快速掌握 MongoDB 数据库
本课程主要讲解MongoDB数据库的基本知识,包括MongoDB数据库的安装、配置、服务的启动、数据的CRUD操作函数使用、MongoDB索引的使用(唯一索引、地理索引、过期索引、全文索引等)、MapReduce操作实现、用户管理、Java对MongoDB的操作支持(基于2.x驱动与3.x驱动的完全讲解)。 通过学习此课程,读者将具备MongoDB数据库的开发能力,并且能够使用MongoDB进行项目开发。 &nbsp; 相关的阿里云产品:云数据库 MongoDB版 云数据库MongoDB版支持ReplicaSet和Sharding两种部署架构,具备安全审计,时间点备份等多项企业能力。在互联网、物联网、游戏、金融等领域被广泛采用。 云数据库MongoDB版(ApsaraDB for MongoDB)完全兼容MongoDB协议,基于飞天分布式系统和高可靠存储引擎,提供多节点高可用架构、弹性扩容、容灾、备份回滚、性能优化等解决方案。 产品详情: https://www.aliyun.com/product/mongodb
目录
打赏
0
1
1
0
114
分享
相关文章
MongoDB保姆级指南(下):无缝集成SpringData框架,一篇最全面的Java接入指南!
前面的两篇文章已经将MongoDB大多数知识进行了阐述,不过其中的所有内容,都基于原生的MongoDB语法在操作。可是,在实际的日常开发过程中,我们并不会直接去接触MongoDB,毕竟MongoDB只能算作是系统内的一个组件,无法仅依靠它来搭建出一整套系统。
532 1
SpringData操作MongoDB
通过SpringData读写MongoDB基础操作
6696 0
如何保证分布式文件系统的数据一致性
分布式文件系统需要向上层应用提供透明的客户端缓存,从而缓解网络延时现象,更好地支持客户端性能水平扩展,同时也降低对文件服务器的访问压力。当考虑客户端缓存的时候,由于在客户端上引入了多个本地数据副本(Replica),就相应地需要提供客户端对数据访问的全局数据一致性。
31852 78
如何保证分布式文件系统的数据一致性
HTML5+CSS3前端入门教程---从0开始通过一个商城实例手把手教你学习PC端和移动端页面开发第8章FlexBox布局(上)
HTML5+CSS3前端入门教程---从0开始通过一个商城实例手把手教你学习PC端和移动端页面开发第8章FlexBox布局
17655 18
灵骏可预期网络:Built for AI Infrastructure
通用人工智能离我们越来越近,全世界的关注和投入正在带来日新“周”异的变化。回顾人工智能的诞生和发展历程,人类计算能力的进步几乎牵动了每一次的重大技术突破,当前的大模型热潮更是如此,只是动辄千万亿参数级的模型体量,所需计算资源远超单颗芯片的上限,超大规模的计算集群成为支撑技术发展和应用创新的关键基础设施。面向智能:云基础设施网络技术面临新挑战如何突破单个芯片、单个服务器节点的算力上限,在超大规模情况
31193 10
灵骏可预期网络:Built for AI Infrastructure
设计模式(C++版)
看懂UML类图和时序图30分钟学会UML类图设计原则单一职责原则定义:单一职责原则,所谓职责是指类变化的原因。如果一个类有多于一个的动机被改变,那么这个类就具有多于一个的职责。而单一职责原则就是指一个类或者模块应该有且只有一个改变的原因。bad case:IPhone类承担了协议管理(Dial、HangUp)、数据传送(Chat)。good case:里式替换原则定义:里氏代换原则(Liskov 
36193 19
设计模式(C++版)
带你简单了解Chatgpt背后的秘密:大语言模型所需要条件(数据算法算力)以及其当前阶段的缺点局限性
带你简单了解Chatgpt背后的秘密:大语言模型所需要条件(数据算法算力)以及其当前阶段的缺点局限性
24468 14
重生之---我测阿里云U1实例(通用算力型)
阿里云产品全线降价的一力作,2023年4月阿里云推出新款通用算力型ECS云服务器Universal实例,该款服务器的真实表现如何?让我先测为敬!
36515 15
重生之---我测阿里云U1实例(通用算力型)

推荐镜像

更多
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等

登录插画

登录以查看您的控制台资源

管理云资源
状态一览
快捷访问