Hyemi Lee

Hyemi Lee

주니어 개발자의 삽질과 기록

Spring, JDBC

JdbcTemplate 클래스

  • JDBC 프로그램을 이용하려면 작성해야할 코드가 너무 많다
  • DB연동에 필요한 자바 코드를 처리해주고 개발자는 SQL 구문만 관리할 수 있도록 지원한다
  • GoF디자인 패턴 중 템플릿 메소드 패턴이 적용된 클래스이다
  • 템플릿 메소드 패턴 : 복잡,반복되는 알고리즘을 캡슐화해서 재사용하는 패턴으로 정의할 수 있다

예제

  • maven등록

<!-- DBCP관련 설정 -->
<dependency>
 <groupId>commons-dbcp</groupId>
 <artifactId>commons-dbcp</artifactId>
 <version>1.4</version>
</dependency>
<!-- Spring -->
<dependency>
 <groupId>org.springframework</groupId>
 <artifactId>spring-jdbc</artifactId>
 <version>${org.springframework-version}</version>
</dependency>
  • spring container 설정
<!-- DB로부터의 커넥션 -->
<!-- DataSource설정 -->
<context:property-placeholder location="classpath:config/database.properties"/>
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
 <property name="driverClassName" value="${jdbc.driver}" />
 <property name="url" value="${jdbc.url}" />
 <property name="username" value="${jdbc.username}" />
 <property name="password" value="${jdbc.password}" />
</bean>
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
 <property name="dataSource" ref="dataSource" />
</bean>
  • config/database.properties
jdbc.driver=org.h2.Driver
jdbc.url=jdbc:h2:mem:testdb;DB_CLOSE_DELAY=-1
jdbc.username=sa
jdbc.password=
  • BoardDAOSpring.java
    • @Repository : 객체 생성
    • @Autowired : JdbcTemplate 클래스 의존성 주입
// DAO(Data Access Object)
@Repository // 객체 생성 @Component와 비슷한일을 하지만 데이터 관리에 더 특화되어있다
public class BoardDAOSpring {
	@Autowired // 의존성주입 해당 객체는 설정파일에서 bean으로 만들어줬다
	private JdbcTemplate jdbcTemplate;
	// SQL 쿼리문
	private final String BOARD_INSERT 	= "insert into BOARD (seq, title, writer, content) values ( (select nvl(max(seq), 0)+1 from board), ?,?,?)";
	//-- CRUD 기능 메소드 구현
	// 글 등록
	public void insertBoard(BoardVO vo) {
		System.out.println("==>SPRING JDBC로 insertBoard() 기능 처리");
		jdbcTemplate.update(BOARD_INSERT, vo.getTitle(), vo.getWriter(), vo.getContent());
	} 
 // ...중략

Reference

  • 스프링 퀵 스타트-채규태 지음

Share on

Twitter Facebook LinkedIn

You may also enjoy

Redis Stream

2021年04月28日

Stream Stream은 로그 데이터를 처리하게위해 5.0에서 새로 도입된 데이터 타입입니다. 대량의 데이터가 연속적으로 발생할때 처리하기 위해 등장했습니다. 기존 데이터를 수정하지 않고 오직 추가로 발생합니다. 이런 종류의 데이터를 stream or log데이터...

Study, Object, chapter2&3 presentation

2021年04月20日

chapter03. 역할, 책임, 협력 객체지향 설계란, 올바른 객체에게 올바른 책임을 할당하면서 낮은 결합도와 높은 응집도를 가진 구조를 창조하는 활동이다.

Spring, chatting 프로그램 만들기, Reactive란?

2020年06月16日

Reactive 막힘없이 흘러다니는 data(event)를 통해 사용자에게 자연스러운 응답을 주고 규모 탄력적으로 리소스를 사용하며 실패에 있어서 유연하게 대처한다 모든 지점에서 블럭 되지 않게 하자 oop와 같은 패러다임 모든 것을 비동기적인 data의 strea...