[JSP 게시판 만들기] - 게시판에 게시물DB 출력하기
○ 게시판에 게시물DB 출력하기 |
// ContentDBProcess.java (아래 두 메소드 추가) // 특정한 페이지에서 10개만큼의 게시물 출력하기 위한 public ArrayList<Content> getList(int pageNumber){ String SQL = "SELECT * FROM content WHERE contentNum < ? ORDER BY contentNum DESC LIMIT 10"; ArrayList<Content> list = new ArrayList<Content>(); try { PreparedStatement pstmt = conn.prepareStatement(SQL); pstmt.setInt(1, getNext() - (pageNumber - 1) * 10); rs = pstmt.executeQuery(); while(rs.next()) { Content content = new Content(); content.setContentNum(rs.getInt(1)); content.setContentTitle(rs.getString(2)); content.setContentUser(rs.getString(3)); content.setContentDate(rs.getString(4)); content.setContentDetail(rs.getString(5)); list.add(content); } } catch(Exception e) { e.printStackTrace(); } return list; // 특정 페이지에 맞는 게시물들을 리스트에 담겨서 반환한다 }
// 특정 페이지가 존재하는지 확인(다음 페이지) public boolean nextPage(int pageNumber) { String SQL = "SELECT * FROM content WHERE contentNum < ?"; try { PreparedStatement pstmt = conn.prepareStatement(SQL); pstmt.setInt(1, getNext() - (pageNumber -1) * 10); rs = pstmt.executeQuery(); if(rs.next()) { return true; } } catch (Exception e) { e.printStackTrace(); } return false; } // content.jsp (전체) <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ page import = "java.io.PrintWriter" %> <%@ page import = "content.ContentDBProcess" %> <%@ page import = "content.Content" %> <%@ page import = "java.util.ArrayList" %> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <!-- 부트스트랩 사용하기 위해 --> <meta name="viewport" content="width=device-width, initial-scale=1"> <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css"> <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script> <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script> <title>게시판 페이지</title> <!-- 링크를 달때쓰는 태그들을 검은색으로 만들고 밑줄이 그어지지 않게 스타일 설정 --> <style type="text/css"> a, a:hover { color: #000000; text-decoration: none; } </style> </head> <body> <% String userEmail = null; if(session.getAttribute("userEmail") != null){ userEmail = (String) session.getAttribute("userEmail"); } int pageNumber = 1; if(request.getParameter("pageNumber") != null){ pageNumber = Integer.parseInt(request.getParameter("pageNumber")); } %> <div class="container"> <h2>게시판</h2> <table class="table table-hover"> <thead> <tr> <th>번호</th> <th>제목</th> <th>글쓴이</th> <th>작성일</th> </tr> </thead> <tbody> <!-- db에서 실제적으로 게시물 데이터 뽑아오기 위한 --> <% ContentDBProcess contentDBProcess = new ContentDBProcess(); ArrayList<Content> list = contentDBProcess.getList(pageNumber); for(int i=0; i<list.size(); i++){ %> <tr> <td><%= list.get(i).getContentNum() %></td> <td><a href="view.jsp?contentNum=<%= list.get(i).getContentNum() %>"><%= list.get(i).getContentTitle() %></a></td> <td><%= list.get(i).getContentUser() %></td> <td><%= list.get(i).getContentDate().substring(0, 11) + list.get(i).getContentDate().substring(11, 13) + "시 " + list.get(i).getContentDate().substring(14, 16) + "분 " %></td> </tr> <% } %> </tbody> </table> <% if(pageNumber != 1){ %> <a href="content.jsp?pageNumber=<%=pageNumber -1 %>" class="btn btn-success btn-arraw-left">이전</a> <% // 다음 페이지가 존재한다면 } if(contentDBProcess.nextPage(pageNumber + 1)) { %> <a href="content.jsp?pageNumber=<%=pageNumber +1 %>" class="btn btn-success btn-arraw-left">다음</a> <% } %> <a href="contentWrite.jsp" class="btn btn-primary pull-right">글쓰기</a> </div> </body> </html> |
'JSP 게시판 만들기' 카테고리의 다른 글
[JSP 게시판 만들기] - 특정 게시물 수정하기 (0) | 2018.03.11 |
---|---|
[JSP 게시판 만들기] - 특정 게시물을 클릭하여 자세히 보기 (0) | 2018.03.11 |
[JSP 게시판 만들기] - 글쓰기 기능 + DB 구현하기 (0) | 2018.03.11 |
[JSP 게시판 만들기] - 글쓰기 게시판 만들기 (0) | 2018.03.11 |
[JSP 게시판 만들기] - 게시판 데이터베이스 생성하기 (0) | 2018.03.11 |