Riucc's Storage
RSS
태그
관리
쓰기
카테고리
  • IT (593)
    • 정리 (0)
    • C# (42)
    • ASP.NET MVC (16)
    • JQuery&Javascript (12)
    • CSS (11)
    • 데이터베이스 (32)
    • Windows Server (6)
    • Active Directory (3)
    • Exchange (9)
    • JAVA (2)
    • JSP (39)
    • JSP 게시판 만들기 (21)
    • JSP 개발 참고 (15)
    • JSP 안드로이드 (4)
    • Servlet (17)
    • Spring (42)
    • HTML (14)
    • NodeJS (46)
    • MongoDB (11)
    • 리눅스 (18)
    • 자료구조 (16)
    • 아이폰 (24)
    • 안드로이드 (68)
    • API 활용하기 (10)
    • 소켓네트워크 (28)
    • 라즈베리파이 (11)
    • AWS클라우드 (10)
    • 빅데이터Hadoop (22)
    • 커널모듈프로그래밍 (8)
    • 기타 (10)
    • 자격증 (26)
Riucc's Storage

[JSP 게시판 만들기] - 게시판에 게시물DB 출력하기

JSP 게시판 만들기|2018. 3. 11. 19:42
336x280(권장), 300x250(권장), 250x250, 200x200 크기의 광고 코드만 넣을 수 있습니다.

○ 게시판에 게시물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

댓글()
카테고리
  • IT (593)
    • 정리 (0)
    • C# (42)
    • ASP.NET MVC (16)
    • JQuery&Javascript (12)
    • CSS (11)
    • 데이터베이스 (32)
    • Windows Server (6)
    • Active Directory (3)
    • Exchange (9)
    • JAVA (2)
    • JSP (39)
    • JSP 게시판 만들기 (21)
    • JSP 개발 참고 (15)
    • JSP 안드로이드 (4)
    • Servlet (17)
    • Spring (42)
    • HTML (14)
    • NodeJS (46)
    • MongoDB (11)
    • 리눅스 (18)
    • 자료구조 (16)
    • 아이폰 (24)
    • 안드로이드 (68)
    • API 활용하기 (10)
    • 소켓네트워크 (28)
    • 라즈베리파이 (11)
    • AWS클라우드 (10)
    • 빅데이터Hadoop (22)
    • 커널모듈프로그래밍 (8)
    • 기타 (10)
    • 자격증 (26)
최근 등록 현황
최근 글
최근 월별 글
최근 댓글
최근 글
최근 월별 글
최근 댓글
최근 글
최근 월별 글
최근 댓글
달력
지난달
2025.6
다음달
일월화수목금토
1234567
891011121314
15161718192021
22232425262728
2930
태그 구름
  • 데이터베이스
  • jsp
  • 카카오 로그인 연동
  • 안드로이드 카카오 로그인 연동
  • 정보처리산업기사 총정리
  • 커널 모듈 프로그래밍
  • 소켓
  • 리눅스
  • 정규형
  • 안드로이드 intent
  • 정보처리산업기사 15년 필기
  • 정보처리산업기사 요약
  • HTML
  • 정보처리산업기사 필기
  • nodejs express
  • 정보처리산업기사 정리
  • 정보처리산업기사 필기 정리
  • 정보처리산업기사 15년
  • 소켓 프로그래밍
  • 이클립스 mysql 연동
  • nodejs MySQL 연동하기(Connection Pool)
  • 정보처리기사 실기 정리
  • 정보처리산업기사 16년
  • 카카오 로그인
  • 이클립스 디비 연동
  • 안드로이드 카카오 로그인
  • 정보처리산업기사 16년 필기
  • 안드로이드
  • 정규화
  • 자료구조
카운터
전체 방문자
오늘
어제
Skin by M1REACT. Designed by M1STORY.TISTORY.COM. Valid XHTML 1.0 and CSS 3. Copyright ⓒ Riucc's Storage. All rights reserved.

티스토리툴바