在 Spring 中访问 MongoDB

1 MongoDB 简介

MongoDB是一个基于分布式文件存储的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。

MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。它支持的数据结构非常松散,是类似jsonbson格式,因此可以存储比较复杂的数据类型。Mongo最大的特点是它支持的查询语言非常强大,其语法有点类似于面向对象的查询语言,几乎可以实现类似关系数据库单表查询的绝大部分功能,而且还支持对数据建立索引

MongoDB 相关概念

在学习 MongoDB 之前需要先了解一些专业术语,常说 MongoDB 是最像关系数据库的 NoSQL 数据库,我们用关系数据库和 MongoDB 做一下对比,方便更清晰地认识它。

SQL 术语/概念MongoDB 术语/概念解释/说明
DataBaseDataBase数据库
TableCollection数据库表/集合
RowDocument数据记录行/文档
ColumnField数据字段/域
indexindex索引
Table joins表连接,MongoDB 不支持
primary keyprimary key主键,MongoDB 自动将 _id 字段设置为主键

2 在 Spring 中使用 MongoDB

这个 demo 主要演示如何在 Spring 使用 MongoTemplate 对 MongoDB 数据库记录的增删改查。
项目结构如下:
在这里插入图片描述

项目配置

引入依赖

<dependency>
	<groupId>org.springframework.boot</groupId>
	<artifactId>spring-boot-starter-data-mongodb</artifactId>
</dependency>

配置 MongoDB 属性

# 如果设置了用户名和密码, 就是用下面的这个
# spring.data.mongodb.uri=mongodb://name:pass@localhost:27017/test
# 没有设置用户名和密码
spring.data.mongodb.uri=mongodb://localhost:27017/test

项目代码

@Document // 将这个类映射为在 MongoDB 同名的 Document
public class User {
    @Id // 作为在在 MongoDB 的 Document 中的主键
    private Long id;
    private String userName;
    private String passWord;
    // setter getter
}
@Component
public class UserRepositoryImpl implements UserRepository {

    @Autowired
    private MongoTemplate mongoTemplate;

    @Override
    public void saveUser(User user) {
        // 会在名为 user 的 Document 中插入一条记录
        // 如果名为 user 的 Document 不存在, MongoDB 会自动创建
        mongoTemplate.save(user);
    }

    @Override
    public User findUserByUserName(String userName) {
        Query query = new Query(Criteria.where("userName").is(userName));
        User user = mongoTemplate.findOne(query, User.class);
        return user;
    }

    @Override
    public long updateUser(User user) {
        Query query = new Query(Criteria.where("id").is(user.getId()));
        Update update = new Update().set("userName", user.getUserName()).set("passWord", user.getPassWord());
        //更新查询返回结果集的第一条
        UpdateResult updateResult = mongoTemplate.updateFirst(query, update, User.class);
        if(updateResult!=null) {
            return updateResult.getModifiedCount();
        }
        return 0;
    }

    @Override
    public void deleteUserById(Long id) {
        Query query = new Query(Criteria.where("id").is(id));
        mongoTemplate.remove(query, User.class);
    }
}

测试

@RunWith(SpringRunner.class)
@SpringBootTest
public class UserRepositoryTest {

    @Autowired
    private UserRepository userRepository;

    @Test
    public void testSave() {
        User user = new User();
        user.setId(2L);
        user.setUserName("张三");
        user.setPassWord("sa123456");
        userRepository.saveUser(user);
    }

    @Test
    public void testfindUserByUserName() {
        User user = userRepository.findUserByUserName("天空");
        System.out.println(user);
    }

    @Test
    public void updateUser(){
        User user=new User();
        user.setId(2l);
        user.setUserName("天空");
        user.setPassWord("fffxxxx");
        userRepository.updateUser(user);
    }

    @Test
    public void testdeleteUserById() {
        userRepository.deleteUserById(2L);
    }
}
  • 执行 testSave() 方法后结果如下:
    在这里插入图片描述
  • 其他几个测试方法的测试结果也符合预期。
  • demo 代码
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值