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

[Spring] - Spring JDBC Template (2) : select 처리

Spring|2018. 7. 24. 15:24
336x280(권장), 300x250(권장), 250x250, 200x200 크기의 광고 코드만 넣을 수 있습니다.

○ Spring JDBC Template (2) : select 처리

 

단 두 줄만 사용하면 깔끔하게 출력이 된다

이전에 예외처리 해주고 연결해주고 등의 복잡하고 긴 코드들을 안써도 되니 얼마나 편한가...


전체 데이터를 받아올때는 template.query() 를 쓰고

특정 데이터를 받아올때는 template.queryForObject() 를 쓴다


// ArrayList 형태로 데이터베이스에서 select 해서 가져오는 구문 (JDBC Template 사용 후)


public ArrayList<BDto> list() {

        // ArrayList<BDto> dtos = new ArrayList<BDto>();  // 데이터 담을 ArrayList 생성

String query = "select bId, bName, bTitle, bContent, bDate, bHit, bGroup, bStep, bIndent from mvc_board order by bGroup desc, bStep asc";

// select 사용하기 위해 query() 메소드를 사용한다

        // query문을 넣어주고, 데이터를 가져올 커맨드 객체를 타입과 명시

return (ArrayList<BDto>) template.query(query, new BeanPropertyRowMapper<BDto>(BDto.class));

        // dtos = (ArrayList<BDto>) template.query(query, new BeanPropertyRowMapper<BDto>(BDto.class));

        // return dtos;

}


// ArrayList 형태로 데이터베이스에서 select 해서 가져오는 구문 (JDBC Template 사용 전)


public ArrayList<BDto> list() {

ArrayList<BDto> dtos = new ArrayList<BDto>();

Connection connection = null;

PreparedStatement preparedStatement = null;

ResultSet resultSet = null;

try {

connection = dataSource.getConnection();

String query = "select bId, bName, bTitle, bContent, bDate, bHit, bGroup, bStep, bIndent from mvc_board order by bGroup desc, bStep asc";

preparedStatement = connection.prepareStatement(query);

resultSet = preparedStatement.executeQuery();

while (resultSet.next()) {

int bId = resultSet.getInt("bId");

String bName = resultSet.getString("bName");

String bTitle = resultSet.getString("bTitle");

String bContent = resultSet.getString("bContent");

Timestamp bDate = resultSet.getTimestamp("bDate");

int bHit = resultSet.getInt("bHit");

int bGroup = resultSet.getInt("bGroup");

int bStep = resultSet.getInt("bStep");

int bIndent = resultSet.getInt("bIndent");

BDto dto = new BDto(bId, bName, bTitle, bContent, bDate, bHit, bGroup, bStep, bIndent);

dtos.add(dto);

}

} catch (Exception e) {

e.printStackTrace();

} finally {

try {

if(resultSet != null) resultSet.close();

if(preparedStatement != null) preparedStatement.close();

if(connection != null) connection.close();

} catch (Exception e) {

e.printStackTrace();

}

}

return dtos;

}


// 데이터베이스에서 특정 부분만 select 해서 가져오는 구문 (JDBC Template 사용 후)


public BDto contentView(String strID) {

String query = "select * from mvc_board where bId = " + strID;


// 특정 부분을 select 사용하기 위해 queryForObject() 메소드를 사용한다

        // query문을 넣어주고, 데이터를 가져올 커맨드 객체를 타입과 명시

        return template.queryForObject(query, new BeanPropertyRowMapper<BDto>(BDto.class));

}


저작자표시 (새창열림)

'Spring' 카테고리의 다른 글

[Spring] - Spring Security (1) : 보안 관련 설정하기  (0) 2018.07.25
[Spring] - Spring JDBC Template (3) : insert update, delete 처리  (0) 2018.07.24
[Spring] - Spring JDBC == JDBC (1) Template 사용하기 위한 설정  (0) 2018.07.18
[Spring] - 오라클 연동 시 HTTP Status 500 - Servlet.init() for servlet appServlet threw exception 에러  (0) 2018.07.18
[Spring] - 프로젝트 설계 및 커맨드 인터페이스와 클래스 (중요)  (0) 2018.07.17

댓글()
카테고리
  • 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
태그 구름
  • 정보처리산업기사 16년
  • 안드로이드 intent
  • 안드로이드 카카오 로그인
  • 정보처리산업기사 16년 필기
  • 정보처리산업기사 필기
  • 이클립스 mysql 연동
  • 안드로이드 카카오 로그인 연동
  • 정보처리기사 실기 정리
  • 정보처리산업기사 요약
  • nodejs MySQL 연동하기(Connection Pool)
  • 카카오 로그인 연동
  • 이클립스 디비 연동
  • 카카오 로그인
  • HTML
  • 정규화
  • 소켓
  • 커널 모듈 프로그래밍
  • 소켓 프로그래밍
  • 정보처리산업기사 15년
  • jsp
  • nodejs express
  • 정보처리산업기사 15년 필기
  • 리눅스
  • 정보처리산업기사 정리
  • 데이터베이스
  • 정보처리산업기사 필기 정리
  • 정규형
  • 정보처리산업기사 총정리
  • 안드로이드
  • 자료구조
카운터
전체 방문자
오늘
어제
Skin by M1REACT. Designed by M1STORY.TISTORY.COM. Valid XHTML 1.0 and CSS 3. Copyright ⓒ Riucc's Storage. All rights reserved.

티스토리툴바