前提・実現したいこと
jspでテーブルの検索結果が0件だった場合、「該当する書籍は存在しません」
と表示したい。
該当のソースコード
servlet
1package jp.co.sss.book.bean; 2 3import java.sql.Date; 4 5public class Book { 6 7 /** 書籍ID */ 8 private int bookId; 9 10 /** 書籍名 */ 11 private String bookName; 12 13 /** 著者 */ 14 private String author; 15 16 /** 発行日 */ 17 private Date publicationDate; 18 19 /** 在庫 */ 20 private int stock; 21 22 /** ジャンルID */ 23 private Genre genre; 24 25 /** 26 * ブックIDを取得 27 * 28 * @return ブックID 29 */ 30 public int getBookId() { 31 return bookId; 32 } 33 34 /** 35 * ブックIDを保存 36 * 37 * @param bookId 38 * ブックID 39 */ 40 public void setBookId(int bookId) { 41 this.bookId = bookId; 42 } 43 44 public String getBookName() { 45 return bookName; 46 } 47 48 public void setBookName(String bookName) { 49 this.bookName = bookName; 50 } 51 52 public void setAuthor(String author) { 53 this.author = author; 54 } 55 56 public String getAuthor() { 57 return author; 58 } 59 60 public Date getPublicationDate() { 61 return publicationDate; 62 } 63 64 public void setPublicationDate(Date publicationDate) { 65 this.publicationDate = publicationDate; 66 } 67 68 public int getStock() { 69 return stock; 70 } 71 72 public void setStock(int stock) { 73 this.stock = stock; 74 } 75 76 public Genre getGenre() { 77 return genre; 78 } 79 80 public void setGenre(Genre genre) { 81 this.genre = genre; 82 } 83}
servlet
1package jp.co.sss.book.dao; 2 3import java.sql.Connection; 4import java.sql.PreparedStatement; 5import java.sql.ResultSet; 6import java.sql.SQLException; 7import java.util.ArrayList; 8import java.util.List; 9 10import jp.co.sss.book.bean.Book; 11import jp.co.sss.book.bean.Genre; 12 13public class BookSerchDao { 14 15 /* 16 * 書名検索 17 */ 18 public static List<Book> findByBookName(String bookName){ 19 20 Connection con = null; 21 PreparedStatement ps = null; 22 ResultSet rs = null; 23 24 List<Book> bookSerch = new ArrayList<Book>(); 25 26 try { 27 con = DBManager.getConnection(); 28 29 String sql = "SELECT * FROM book b INNER JOIN genre g ON b.genre_id = 30 g.genre_id WHERE b.book_name LIKE ?"; 31 32 ps = con.prepareStatement(sql); 33 ps.setString(1, "%" + bookName + "%"); 34 rs = ps.executeQuery(); 35 36 while(rs.next()) { 37 Book book = new Book(); 38 book.setBookId(rs.getInt("book_id")); 39 book.setBookName(rs.getString("book_name")); 40 book.setAuthor(rs.getString("author")); 41 book.setPublicationDate(rs.getDate("publication_date")); 42 book.setStock(rs.getInt("stock")); 43 44 Genre genre = new Genre(); 45 genre.setGenreId(rs.getInt("genre_id")); 46 genre.setGenreName(rs.getString("genre_name")); 47 48 book.setGenre(genre); 49 bookSerch.add(book); 50 } 51 52 }catch (SQLException e) { 53 e.printStackTrace(); 54 } finally { 55 DBManager.close(rs); 56 DBManager.close(ps); 57 DBManager.close(con); 58 } 59 return bookSerch; 60 } 61 62}
servlet
1package jp.co.sss.book.servlet; 2 3import java.io.IOException; 4import java.util.List; 5 6import javax.servlet.ServletException; 7import javax.servlet.annotation.WebServlet; 8import javax.servlet.http.HttpServlet; 9import javax.servlet.http.HttpServletRequest; 10import javax.servlet.http.HttpServletResponse; 11 12import jp.co.sss.book.bean.Book; 13import jp.co.sss.book.dao.BookSerchDao; 14 15 16@WebServlet("/BookSerch") 17public class BookSerch extends HttpServlet { 18 private static final long serialVersionUID = 1L; 19 20 protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { 21 22 23 String bookName = (String)request.getParameter("bookName"); 24 List<Book> bookSerch = BookSerchDao.findByBookName(bookName); 25 26 request.setAttribute("bookSerch", bookSerch); 27 request.getRequestDispatcher("/jsp/select/book_serch.jsp").forward(request, response); 28 } 29}
jsp
1<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> 2<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%> 3<%@ page import="jp.co.sss.book.bean.Book" %> 4<!DOCTYPE html> 5<html lang="ja"> 6 <head> 7 <meta charset="UTF-8"> 8 <link href="<%=request.getContextPath()%>/css/style.css" rel="stylesheet" type="text/css" /> 9 <title>書籍一覧画面</title> 10 </head> 11 12 <body> 13 <%@include file="/jsp/common/header.jsp"%> 14 <a href="<%=request.getContextPath()%>/logout">ログアウト</a> 15 <div id="main"> 16 <table> 17 <tr> 18 <th>書籍ID</th> 19 <th>書籍名</th> 20 <th>筆者</th> 21 <th>発行日</th> 22 <th>在庫</th> 23 <th>ジャンル</th> 24 </tr> 25 26 <c:forEach var="book" items="${bookSerch}"> 27 <tr> 28 <td><c:out value="${book.bookId}" /></td> 29 <td><c:out value="${book.bookName}" /></td> 30 <td><c:out value="${book.author}" /></td> 31 <td><c:out value="${book.publicationDate}" /></td> 32 <td><c:out value="${book.stock}" /></td> 33 <td><c:out value="${book.genre.genreName}" /></td> 34 35 </tr> 36 </c:forEach> 37 </table> 38 <a href="<%=request.getContextPath()%>/jsp/select/list.jsp">一覧表示に戻る</a> 39 </div> 40 <%@include file="/jsp/common/footer.jsp"%> 41 </body> 42</html>
よろしくお願いします。
回答1件
あなたの回答
tips
プレビュー