Background Image
Java
2009.04.01 08:32

Spring framework 사용 예제

조회 수 53134 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

 

Spring에서 CUBRID 사용하기

소개: Spring DAO package을 통해 CUBRID를 사용하는 방법을 간단한 샘플을 통해 설명하고자 한다.

이 문서에서 Spring Spring DAO의 상세내역은 별도로 설명하지 않고 Spring DAO를 통해 CUBRID Connection을 맺고 이를 통해 데이터를 추가, 조회하는 방법을 설명한다.

예제 수행을 위한 Java설치 및 JDBC 환경설정은 CUBRID 매뉴얼의 큐브리드 시작 > JDBC를 이용한 프로그램 작성 > JDBC 환경 설정을 참조하기 바란다.

 

적용 대상: CUBRID2008, JDK1.6.0_04, Spring Framework 2.5.6

Spring에서 CUBRID 사용하기

환경 설정

http://www.springsource.org/download 에서 Spring framework을 다운로드 하여 압축을 푼 후 dist 디렉토리의 spring.jar의 위치를 classpath에 설정한다.

Spring을 사용하기 위해서는

connon-loggin-1.1.1.jar http://commons.apache.org/downloads/download_logging.cgi

commons-dbcp-1.2.2.jar  http://commons.apache.org/downloads/download_dbcp.cgi

commons-pool-1.3.jar http://commons.apache.org/downloads/download_pool.cgi

commons-collections-3.2.1.jar http://commons.apache.org/downloads/download_collections.cgi

에서 각각의 최신 릴리스 바이너리 파일을 다운 받아 압축을 풀면 위 파일들을 얻을 수 있다. 이 파일들도 classpath에 설정한다.

샘플 소스 저장 및 컴파일 할 위치를 classpath에 설정한다.

간단 예제

다음은 Spring을 통해 CUBRID Connection을 맺고 데이터를 추가, 조회하는 것을 간단하게 구성한 예제이다.

테스트를 위해 아래 테이블 생성 스크립트를 DB에서 실행한다.

create table emp(

name varchar(20), //이름

title varchar(10),//직위

email varchar(100),//이메일

phone varchar(20)//전화번호

)

예제 소스는 firstSpringApp 패키지로 이루어져 있으므로 특정 폴더에 firstSpringApp 폴더를 생성하여 아래 스크립트들을 작성하여 저장한다.

applicationContext.xml

데이터베이스 접속 정보 및 사용될 객체가 정의된 configuration metadata이다.

<?xml version="1.0" encoding="UTF-8"?>

<beans xmlns="http://www.springframework.org/schema/beans"

                           xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

                           xsi:schemaLocation="

http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd">

<!-- jdbc datasource 설정 -->

                           <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" >

                           <property name="driverClassName">

<!-- jdbc 드라이버 클래스 이름 -->

                                                <value>cubrid.jdbc.driver.CUBRIDDriver</value>

                           </property>

                           <property name="url">

<!-- 접속 할 데이터베이스 url jdbc:cubrid:IP:PORT:DB이름::: 형식으로 입력 -->

                                                <value>jdbc:cubrid:localhost:33000:demodb:::</value>

                           </property>

<!-- 데이터베이스에 접속할 아이디, 패스워드 설정. -->

                           <property name="username">

                                                <value>public</value>

                           </property>

                           <property name="password">

                                                <value></value>

                           </property>                    

                           </bean>

                           <!-- 질의 수행 객체 -->  

                           <bean id="EmpDao" class="firstSpringApp.EmpDao">

                           <property name="dataSource"><ref local="dataSource"/></property>

                           </bean>

</beans>

Emp.java

package firstSpringApp;

public class Emp {

                                               String name = "";

                                               String title = "";

                                               String email = "";

                                               String phone = "";        

                                               public String getName(){

                                                                    return name;

                                               }

                                               public void setName(String name){

                                                                    this.name = name;

                                               }

                                               public String getTitle(){

                                                                    return title;

                                               }

                                               public void setTitle(String title){

                                                                    this.title = title;

                                               }

                                               public String getEmail(){

                                                                    return email;

                                               }

                                               public void setEmail(String email){

                                                                    this.email = email;

                                               }

                                               public String getPhone(){

                                                                    return phone;

                                               }

                                               public void setPhone(String phone){

                                                                    this.phone = phone;

                                                }

}

EmpDao.java

package firstSpringApp;

 

import java.util.List;

import java.sql.*;

import javax.sql.DataSource;

import org.springframework.jdbc.core.JdbcTemplate;

import org.springframework.jdbc.core.RowMapper;

import firstSpringApp.Emp;

 

public class EmpDao {

                           private DataSource dataSource;

                           private JdbcTemplate jdbcTemplate;

                          

                           public DataSource getDataSource(){

                                                return dataSource;

                           }                  

                           public void setDataSource(DataSource dataSource) {

                                                this.dataSource = dataSource;

                                                // datasource를 가지고 JdbcTemplate를 생성한다.

                                                this.jdbcTemplate = new JdbcTemplate(dataSource);

                           }

                           // insert 수행

                           public int add(Emp emp){

                                                String sql = "insert into emp(name,title,email,phone) values(?, ?, ?, ?)";

                                                // 입력 받은 emp객체를 update 실행 인자로 사용하기 위해 Object[]로 변경.

                                                Object[] args = {emp.getName(),emp.getTitle(),emp.getEmail(),emp.getPhone()};

                                                return jdbcTemplate.update(sql,args);

                           }

                           // name에 해당하는 데이터 조회

                           public Emp getEmp(String name){

                                                String sql = "select * from emp where name = ?";

                                                // RowMapper ResultSet의 레코드와 객체를 매핑시키는 역할을 한다.

                                                RowMapper mapper = new RowMapper(){

                                                                    public Object mapRow(ResultSet rs, int rowNum) throws SQLException{

                                                                                        Emp emp = new Emp();

                                                                                        emp.setName(rs.getString("name"));

                                                                                        emp.setTitle(rs.getString("title"));

                                                                                        emp.setEmail(rs.getString("email"));

                                                                                        emp.setPhone(rs.getString("phone"));

                                                                                        return emp;

                                                                    }

                                                };

                                                // 입력 받은 name queryForObject 실행 인자로 사용하기 위해 Object[]로 변경.

                                                Object[] args = {name};

                                                return (Emp)jdbcTemplate.queryForObject(sql, args, mapper);

                           }

                           // 전체 데이터 조회

                           public List<Emp> searchAll(){

                                                String sql = "select * from emp";

                                                // RowMapper ResultSet의 레코드와 객체를 매핑시키는 역할을 한다.

                                                RowMapper mapper = new RowMapper(){

                                                                    public Object mapRow(ResultSet rs, int rowNum) throws SQLException{

                                                                                        Emp emp = new Emp();

                                                                                        emp.setName(rs.getString("name"));

                                                                                        emp.setTitle(rs.getString("title"));

                                                                                        emp.setEmail(rs.getString("email"));

                                                                                        emp.setPhone(rs.getString("phone"));

                                                                                        return emp;

                                                                    }

                                                };

                                                return jdbcTemplate.query(sql, mapper);

                           }

}

JdbcTestClient.java

package firstSpringApp;

 

import org.springframework.context.ApplicationContext;

import org.springframework.context.support.ClassPathXmlApplicationContext;

import java.util.*;

import firstSpringApp.Emp;

 

public class JdbcTestClient {

                           public static void main(String[] args) {

                                                // configuration metadata를 읽는다.

                                                ApplicationContext ac = new ClassPathXmlApplicationContext(

                                                                                        new String[] { "firstSpringApp/applicationContext.xml" });

                                                // EmpDao 객체를 생성.

                                                EmpDao empdao = (EmpDao) ac.getBean("EmpDao");

                                                // 실행인자 in 인 경우 insert 수행                         

                                                if (args.length !=0 && "in".equals(args[0])) {

                                                                    Emp emp = new Emp();

                                                                    emp.setName("홍길동");

                                                                    emp.setTitle("사원");

                                                                    emp.setEmail("hong@korea.com");

                                                                    emp.setPhone("010-123-4567");

                                                                    empdao.add(emp);

                                                }else if (args.length !=0 && "view".equals(args[0])) {

                                                                    // 실행인자 view 인 경우 한 건 조회수행

                                                                    Emp emp = empdao.getEmp("홍길동");

                                                                    System.out.println("====== view =========");

                                                                    System.out.println("name:"+emp.getName());

                                                                    System.out.println("title:"+emp.getTitle());

                                                                    System.out.println("email:"+emp.getEmail());

                                                                    System.out.println("phone:"+emp.getPhone());

                                                                    System.out.println("=====================");

                                                }else if (args.length !=0 && "all".equals(args[0])) {

                                                                    // 실행인자 all 인 경우 전체 조회수행

                                                                    List lemp = (List)empdao.searchAll();

                                                                    Iterator empIter= lemp.iterator();

                                                                    System.out.println("======= all list ======");

                                                                    while(empIter.hasNext()){

                                                                                        Emp emplist = (Emp)empIter.next();

                                                                                        System.out.println("name:"+emplist.getName());

                                                                                        System.out.println("title:"+emplist.getTitle());

                                                                                        System.out.println("email:"+emplist.getEmail());

                                                                                        System.out.println("phone:"+emplist.getPhone());

                                                                                        System.out.println("=====================");

                                                                    }                  

                                                }

                           }

}

위의 소스 코드를 컴파일 한 후 실행하면 아래와 같은 결과가 나타난다.

// insert 수행

c:testspring>java firstSpringApp.JdbcTestClient in

2009. 1. 8 오후 5:43:29 org.springframework.context.support.AbstractApplicationC

ontext prepareRefresh

…(생략)

정보: Pre-instantiating singletons in org.springframework.beans.factory.support.

DefaultListableBeanFactory@1b1aa65: defining beans [hello,dataSource,EmpDao]; ro

ot of factory hierarchy

c:testspring>

// 한 건 조회 수행

c:testspring>java firstSpringApp.JdbcTestClient view

2009. 1. 8 오후 5:46:04 org.springframework.context.support.AbstractApplicationC

ontext prepareRefresh

… (생략)

====== view =========

name:홍길동

title:사원

email:hong@korea.com

phone:010-123-4567

=====================

c:testspring>

// 전체 조회 수행

c:testspring>java firstSpringApp.JdbcTestClient all

2009. 1. 8 오후 5:48:04 org.springframework.context.support.AbstractApplicationC

ontext prepareRefresh

…(생략)

======= all list ======

name:홍길동

title:사원

email:hong@korea.com

phone:010-123-4567

=====================

 


List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
46 기타 트랜잭션과 LOCK 초급과정 정만영 2010.07.01 20760
45 기타 CUBRID 2008 R2.0 추가 및 변경 기능 소개 janus 2009.08.15 20663
44 기타 오래 걸리는 질의 및 동일 시간에 수행 중인 질의 추출하기 손승일 2009.05.26 20069
43 기타 DB의 스키마와 데이터를 파일로 내려받기 seongjoon 2009.08.17 20009
42 Java CUBRID와 MyBATIS 빠르게 연동하기 file 김승훈 2015.05.07 19143
41 기타 CUBRID2008데이터타입, 함수와 힌트사용법 및 예약어 cubebridge 2009.07.28 18844
40 기타 예제로 배우는 CUBRID 스터디 문학청년 2009.12.29 18558
39 기타 CUBRID 개발 가이드 janus 2009.12.09 18368
38 Install CUBRID 2008 + Textyle 설치 가이드 3 1 Prototype 2009.07.29 18287
37 기타 python 에서 broker_log_top 사용 1 admin 2009.04.01 17831
36 기타 CUBRID 32bit VS 64bit janus 2009.08.15 17483
35 기타 CUBRID 주요 명령 요약 정리 정만영 2009.08.17 17187
34 기타 CUBRID 2008 R2.0의 CM변경사항 janus 2009.11.20 17045
33 기타 CSQL 인터프리터 사용방법 정만영 2016.03.03 16647
32 기타 CUBRID 2008 + XE 설치 가이드 [R2.0] Prototype 2009.08.27 16573
31 기타 CUBRID 볼륨 공간 재사용률 비교 - 2008 R3.1 vs. 2008 R4.0 file admin 2011.07.14 16555
30 기타 CUBRID2008_보안설정[R2.0] seongjoon 2009.08.17 16272
29 기타 CUBRID Manager login 안내 seongjoon 2009.08.17 16201
28 기타 멀티미디어 데이터 관리를 위한 CUBRID GLO Method 활용 janus 2009.12.11 16191
27 기타 CUBRID 2008 1.x 에서 CUBRID 2.0 64bit로 Migration 3 janus 2009.08.15 15860
Board Pagination Prev 1 2 3 4 5 6 7 8 9 Next
/ 9

Contact Cubrid

대표전화 070-4077-2110 / 기술문의 070-4077-2113 / 영업문의 070-4077-2112 / Email. contact_at_cubrid.com
Contact Sales