使用MongoDB和Spring Boot创建 CRUD应用示例

原创
03/02 11:02
阅读数 3.9K

介绍

在这篇文章中,我将展示如何使用Spring Boot和MongoDB构建一个简单的CRUD REST应用程序示例。我知道你的第一个问题是MongoDB是什么?

MongoDB是什么?

MongoDB是一个NoSQL文档数据库。在这个数据库中,记录是document,其行为很像JSON对象。所以它主要是键值对。

使用MongoDB作为数据库的主要优点是:

  • MongoDB是一种无模式文档数据库。一个集合包含不同的文档。
  • 单个对象的结构是清晰的。
  • 没有复杂的连接。
  • 深查询能力。
  • 易于扩展。

以下是在企业应用中使用MongoDB或类似的NoSQL数据库的几个原因:

  • 更快的JSON数据检索。
  • 很容易在属性上添加索引。
  • 用于分片——分片是跨多台机器存储数据记录的过程。在跨多台机器存储数据时,通常会根据某些标准对数据进行分区。
  • 更新快。
  • 容易查询。

先决条件

要创建这个示例应用程序,你需要:

  • Spring Boot(版本2.4.1)
  • MongoDB
  • Gradle
  • Java

Spring Boot CRUD应用程序

作为本文的一部分,我将构建一个REST CRUD应用程序。这包括

  • 一个图书馆-我们将在MongoDB数据库中创建一个图书馆集合。

  • 我们将按作者来存放这些书。

  • 用户可以调用REST API按作者检索图书。

  • 用户可以调用REST API来检索图书馆中的所有图书。

  • POST - /v1/mongodbapp/books -添加一本书。

  • GET - /v1/mongodbapp/books——从库中检索所有的图书。

  • GET - /v1/mongodbapp/books/id -检索特定的图书。

  • DELETE—/v1/mongodbapp/books/id—从库中删除一本书。

如何使用MongoDB和Spring Boot CRUD

为了开始创建这个应用程序,我们将使用gradle来处理我们的依赖并构建应用程序。在Spring Boot应用程序中添加以下依赖项:

implementation 'org.springframework.boot:spring-boot-starter-data-mongodb' implementation 'org.springframework.boot:spring-boot-starter-web'

一旦我们有了这些依赖,我们将能够连接到mongodb数据库。但是我们仍然需要添加数据库的位置。我们将在application.properties中添加所需的属性。如下:

spring.data.mongodb.host = localhostspring.data.mongodb.port=27017 spring.data.mongodb.database=library

这将允许我们连接到运行在主机localhost上的端口27017上的MongoDB数据库,并且数据库是library。

定义数据模型

作为图书馆的一部分,我们将需要书籍。我们的主要数据对象是Book。这个数据模型将包括书名、作者和ISBN。具体内容如下:​​​​​​​

package com.betterjavacode.mongodbdemo.mongodbapp.models;
import org.springframework.data.annotation.Id;import org.springframework.data.mongodb.core.mapping.Document;


@Document(collection = "books")public class Book{ @Id private String id;
 private String title; private String author; private String isbn;
 public Book() {
 }
 public Book(String title, String author, String isbn) { this.title = title; this.author = author; this.isbn = isbn; }
 public String getId() { return id; }
 public void setId(String id) { this.id = id; }
 public String getTitle() { return title; }
 public void setTitle(String title) { this.title = title; }
 public String getAuthor() { return author; }
 public void setAuthor(String author) { this.author = author; }
 public String getIsbn() { return isbn; }
 public void setIsbn(String isbn) { this.isbn = isbn; }}

因为我们使用的是MongoDB,所以@Document注释覆盖了集合书籍。

添加Repository接口

我们需要一个Repository库接口来获取、保存或删除book对象。在repositories包中,我们将添加BookRepository接口:​​​​​​​

package com.betterjavacode.mongodbdemo.mongodbapp.repositories;
import com.betterjavacode.mongodbdemo.mongodbapp.models.Book;import org.springframework.data.mongodb.repository.MongoRepository;
import java.util.List;
public interface BookRepository extends MongoRepository<Book, String>{ List findByTitleContaining(String title); List findByAuthor(String name);}

这个Repository库有两个方法:可以通过标题或作者姓名获取图书。

添加Spring REST API控制器

现在,为了使我们的应用程序REST CRUD,我们将添加一个REST控制器。这个控制器将包含POST、PUT、GET和DELETE API。​​​​​​​

package com.betterjavacode.mongodbdemo.mongodbapp.controller;
import com.betterjavacode.mongodbdemo.mongodbapp.models.Book;import com.betterjavacode.mongodbdemo.mongodbapp.repositories.BookRepository;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.http.HttpStatus;import org.springframework.http.ResponseEntity;import org.springframework.web.bind.annotation.*;
import java.util.ArrayList;import java.util.List;import java.util.Optional;
@CrossOrigin("http://localhost:8080")@RestController@RequestMapping("/v1/mongodbapp")public class BookController{ @Autowired BookRepository bookRepository;
 @GetMapping("/books") public ResponseEntity<List> getAllBooks(@RequestParam(required = false) String bookTitle) { try { List listOfBooks = new ArrayList<>(); if(bookTitle == null || bookTitle.isEmpty()) { bookRepository.findAll().forEach(listOfBooks::add);} else { bookRepository.findByTitleContaining(bookTitle).forEach(listOfBooks::add); }
 if (listOfBooks.isEmpty()) { return new ResponseEntity<>(HttpStatus.NO_CONTENT); }
 return new ResponseEntity<>(listOfBooks, HttpStatus.OK); } catch (Exception e) { return new ResponseEntity<>(null, HttpStatus.INTERNAL_SERVER_ERROR); } }
 @GetMapping("/books/{id}") public ResponseEntity getBookById(@PathVariable("id") String id) { try { Optional bookOptional = bookRepository.findById(id);
 return new ResponseEntity<>(bookOptional.get(), HttpStatus.OK); } catch (Exception e) { return new ResponseEntity<>(null, HttpStatus.INTERNAL_SERVER_ERROR); } }
 @PostMapping("/books") public ResponseEntity addABookToLibrary(@RequestBody Book book) { try { Book createdBook = bookRepository.save(new Book(book.getTitle(), book.getAuthor(), book.getIsbn())); return new ResponseEntity<>(createdBook, HttpStatus.CREATED); } catch (Exception e) { return new ResponseEntity<>(null, HttpStatus.INTERNAL_SERVER_ERROR); } }
 @PutMapping("/books/{id}") public ResponseEntity updateABook(@PathVariable("id") String id, @RequestBody Book book) { Optional bookOptional = bookRepository.findById(id);
 if (bookOptional.isPresent()) { Book updatedBook = bookOptional.get(); updatedBook.setTitle(book.getTitle()); updatedBook.setAuthor(book.getAuthor()); updatedBook.setIsbn(book.getIsbn()); return new ResponseEntity<>(bookRepository.save(updatedBook), HttpStatus.OK); } else { return new ResponseEntity<>(HttpStatus.NOT_FOUND); } }
 @DeleteMapping("/books/{id}") public ResponseEntity deleteABook(@PathVariable("id") String id) { try { bookRepository.deleteById(id); return new ResponseEntity<>(HttpStatus.NO_CONTENT); } catch (Exception e) { return new ResponseEntity<>(HttpStatus.INTERNAL_SERVER_ERROR); } }}

BookController 是我们的REST控制器类。它包括

  • @RestController -将其标记为REST控制器。
  • @CrossOrigin -这个注释允许跨源资源共享(CORS)。这将在REST响应中添加CORS访问控制头。这些头是必需的,因为它允许服务器不仅指定谁可以访问资源,而且指定如何访问资源。
  • 我们添加了不同的方法——addabooktolilibrary将书籍添加到数据库,getAllBooks从数据库中检索书籍。

完整的演示

 

 

 

现在我们已经添加了REST控制器、Repository库方法,我们将构建并运行这个应用程序。作为演示的一部分,我将使用POSTMAN来访问API。

可以从命令行或正在使用的代码编辑器构建应用程序。我更喜欢命令行,所以我已经构建了应用程序。一旦编译完成,你就可以像下面这样运行程序:

java -jar mongodbapp-0.0.1-SNAPSHOT.jar

让我们用POSTMAN给我们的图书馆添加书籍。

如上所示,我们添加了一本书,响应将在数据库中显示已添加的书。

下面的API是一个GET API,用于从数据库中获取所有书籍。

现在,为了显示从库中删除图书,我们将使用delete API。

结论

在这篇文章中,我展示了如何在使用MongoDB数据库时使用Spring Boot创建REST API。我们使用的方法与使用常规SQL数据库时的方法非常相似。在使用NoSQL数据库时,我们必须添加一些更改。

​​​​​​​

 

展开阅读全文
打赏
0
1 收藏
分享
加载中
打赏
0 评论
1 收藏
0
分享
返回顶部
顶部