【SpringBoot】springboot整合mongoDB

目录

1.配置

2.使用

创建实体类

创建MongoDB仓库接口

创建一个控制器


1.配置

创建好springboot工程后

引入mongoDB依赖

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

 在application.properties中配置MongoDB的连接信息

格式如下:

spring.data.mongodb.uri=mongodb://user:password@localhost:27017/mydatabase

 application.yml格式如下

spring:

   data:

mongodb:

uri: mongodb://username:password@localhost:27017/myDatabase 

2.使用

创建实体类

@Document(collection = "users")
public class User {
    @Id
    private String id;
    private String name;
    private int age;


    public User(String id, String name, int age) {
        this.id = id;
        this.name = name;
        this.age = age;
    }

    public String getId() {
        return id;
    }

    public void setId(String id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }
}

@Document 注解用于标注实体类,表示一个实体类映射为MongoDB 中的一个文档

@Id 注解用于标注实体类中的主键

创建MongoDB仓库接口

为每个实体创建一个仓库接口,并使用@Repository注解标记接口

package com.example.demo.repository;

import com.example.demo.po.User;
import org.springframework.data.mongodb.repository.MongoRepository;
import org.springframework.stereotype.Repository;

@Repository
public interface UserRepository extends MongoRepository<User,String> {

}

创建一个控制器

例如

package com.example.demo.controller;


import com.example.demo.po.User;
import com.example.demo.repository.UserRepository;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;

import java.util.List;
import java.util.Optional;

@RestController
@RequestMapping("/users")
public class UserController {
    @Autowired
    private UserRepository userRepository;

    @GetMapping
    public List<User> getAllUsers() {
        return userRepository.findAll();
    }

    @GetMapping("/{id}")
    public Optional<User> getUserById(@PathVariable String id) {
        return userRepository.findById(id);
    }

    @PostMapping
    public User createUser(@RequestBody User user) {
        return userRepository.save(user);
    }



    @DeleteMapping("/{id}")
    public void deleteUser(@PathVariable String id) {
        userRepository.deleteById(id);
    }
}

然后编写相关的服务

类似于mysql 

相关推荐

  1. springBoot整合mongodb

    2024-02-03 16:28:05       22 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-02-03 16:28:05       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-02-03 16:28:05       100 阅读
  3. 在Django里面运行非项目文件

    2024-02-03 16:28:05       82 阅读
  4. Python语言-面向对象

    2024-02-03 16:28:05       91 阅读

热门阅读

  1. SpringBoot整合Flowable最新教程(二)启动流程

    2024-02-03 16:28:05       55 阅读
  2. mysql - 笔记

    2024-02-03 16:28:05       52 阅读
  3. 【NeRF和NLP】一些观察感悟,碎碎念

    2024-02-03 16:28:05       51 阅读
  4. arch linux python venv

    2024-02-03 16:28:05       53 阅读
  5. ASP.NET的GridView控件中,实现同列内容合并

    2024-02-03 16:28:05       57 阅读
  6. DAO设计模式

    2024-02-03 16:28:05       51 阅读
  7. SQL中聚合函数

    2024-02-03 16:28:05       48 阅读
  8. armbian修改docker目录到硬盘

    2024-02-03 16:28:05       40 阅读
  9. Spring Boot 自定义指标

    2024-02-03 16:28:05       52 阅读