From 6f3e150b71daa78be0f970094b0664645d99ee57 Mon Sep 17 00:00:00 2001 From: Rishabh Date: Tue, 5 Nov 2024 21:31:13 +0530 Subject: [PATCH 1/2] Implemented Search Book Functionality --- .../libraryman_api/book/BookController.java | 14 +++++++++++ .../libraryman_api/book/BookRepository.java | 23 +++++++++++++++++++ .../com/libraryman_api/book/BookService.java | 12 ++++++++++ 3 files changed, 49 insertions(+) diff --git a/src/main/java/com/libraryman_api/book/BookController.java b/src/main/java/com/libraryman_api/book/BookController.java index 0e2660f..c3de162 100644 --- a/src/main/java/com/libraryman_api/book/BookController.java +++ b/src/main/java/com/libraryman_api/book/BookController.java @@ -1,6 +1,8 @@ package com.libraryman_api.book; import com.libraryman_api.exception.ResourceNotFoundException; + + import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.domain.Page; import org.springframework.data.domain.PageRequest; @@ -100,4 +102,16 @@ public BookDto updateBook(@PathVariable int id, @RequestBody BookDto bookDtoDeta public void deleteBook(@PathVariable int id) { bookService.deleteBook(id); } + + /** + * Searches book based on title, author, genre, etc. + * + * @param keyword the Keyword to search Book + * @param pageable + * @return + */ + @GetMapping("/search/{keyword}") + public Page searchBook(@PathVariable String keyword, @PageableDefault(page = 0, size = 5, sort = "title") Pageable pageable){ + return bookService.searchBook(keyword,pageable); + } } \ No newline at end of file diff --git a/src/main/java/com/libraryman_api/book/BookRepository.java b/src/main/java/com/libraryman_api/book/BookRepository.java index 013b353..8674be0 100644 --- a/src/main/java/com/libraryman_api/book/BookRepository.java +++ b/src/main/java/com/libraryman_api/book/BookRepository.java @@ -1,10 +1,33 @@ package com.libraryman_api.book; +import org.springframework.data.domain.Page; +import org.springframework.data.domain.Pageable; import org.springframework.data.jpa.repository.JpaRepository; +import org.springframework.data.jpa.repository.Query; +import org.springframework.data.repository.query.Param; import org.springframework.stereotype.Repository; @Repository public interface BookRepository extends JpaRepository { + + /** + * This method use SQL Query for finding book based on + * title, author, genre, publishedYear, etc. By using LIKE operator + * it search from database based on keyword entered. + * + * @param keyword + * @param pageable + * @return + */ + + @Query("SELECT b FROM Book b WHERE " + + "b.title LIKE %:keyword% OR " + + "b.author LIKE %:keyword% OR " + + "b.publisher LIKE %:keyword% OR " + + "b.genre LIKE %:keyword% OR " + + "CAST(b.publishedYear As string) LIKE %:keyword% OR " + + "CAST(b.copiesAvailable As string) LIKE %:keyword%") + Page searchBook(@Param("keyword") String keyword,Pageable pageable); } diff --git a/src/main/java/com/libraryman_api/book/BookService.java b/src/main/java/com/libraryman_api/book/BookService.java index 292684c..a1b5c90 100644 --- a/src/main/java/com/libraryman_api/book/BookService.java +++ b/src/main/java/com/libraryman_api/book/BookService.java @@ -181,4 +181,16 @@ public Book DtoToEntity(BookDto bookDto) { book.setIsbn(bookDto.getIsbn()); return book; } + + /** + *

This method takes String keyword and search book based on + * title, author, genre, publishedYear, etc. from Book Entity.

+ * + * @param keyword + * @param pageable + * @return + */ + public Page searchBook(String keyword,Pageable pageable ){ + return bookRepository.searchBook(keyword,pageable); + } } From 2b2e24efdda683a712b68303be316a9dbaf72195 Mon Sep 17 00:00:00 2001 From: Rishabh Date: Thu, 7 Nov 2024 21:08:24 +0530 Subject: [PATCH 2/2] Implemented Search Functionality --- .../com/libraryman_api/book/BookController.java | 13 +++++++++---- .../com/libraryman_api/book/BookRepository.java | 12 ++++++------ 2 files changed, 15 insertions(+), 10 deletions(-) diff --git a/src/main/java/com/libraryman_api/book/BookController.java b/src/main/java/com/libraryman_api/book/BookController.java index c3de162..766b3b7 100644 --- a/src/main/java/com/libraryman_api/book/BookController.java +++ b/src/main/java/com/libraryman_api/book/BookController.java @@ -105,13 +105,18 @@ public void deleteBook(@PathVariable int id) { /** * Searches book based on title, author, genre, etc. - * + * It uses a keyword parameter to filter the books, and pagination is applied to the search results. + * If no book is found it will return 204(No content found) http response. + * If keyword is null then it will return all books. * @param keyword the Keyword to search Book * @param pageable * @return */ - @GetMapping("/search/{keyword}") - public Page searchBook(@PathVariable String keyword, @PageableDefault(page = 0, size = 5, sort = "title") Pageable pageable){ - return bookService.searchBook(keyword,pageable); + @GetMapping("/search") + public ResponseEntity> searchBook(@RequestParam String keyword, @PageableDefault(page = 0, size = 5, sort = "title") Pageable pageable){ + Page books=bookService.searchBook(keyword,pageable); + if(!books.isEmpty()) + return ResponseEntity.ok(books); + return ResponseEntity.noContent().build(); } } \ No newline at end of file diff --git a/src/main/java/com/libraryman_api/book/BookRepository.java b/src/main/java/com/libraryman_api/book/BookRepository.java index 8674be0..96942f3 100644 --- a/src/main/java/com/libraryman_api/book/BookRepository.java +++ b/src/main/java/com/libraryman_api/book/BookRepository.java @@ -21,12 +21,12 @@ public interface BookRepository extends JpaRepository { */ @Query("SELECT b FROM Book b WHERE " - + "b.title LIKE %:keyword% OR " - + "b.author LIKE %:keyword% OR " - + "b.publisher LIKE %:keyword% OR " - + "b.genre LIKE %:keyword% OR " - + "CAST(b.publishedYear As string) LIKE %:keyword% OR " - + "CAST(b.copiesAvailable As string) LIKE %:keyword%") + + "(LOWER(b.title) LIKE LOWER(CONCAT('%', :keyword, '%')) OR " + + "LOWER(b.author) LIKE LOWER(CONCAT('%', :keyword, '%')) OR " + + "LOWER(b.publisher) LIKE LOWER(CONCAT('%', :keyword, '%')) OR " + + "LOWER(b.genre) LIKE LOWER(CONCAT('%', :keyword, '%')) OR " + + "CAST(b.publishedYear AS string) LIKE %:keyword% OR " + + "CAST(b.copiesAvailable AS string) LIKE %:keyword%)") Page searchBook(@Param("keyword") String keyword,Pageable pageable); }