Background Image
Java
2009.04.01 08:32

Spring framework 사용 예제

조회 수 53135 추천 수 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
번호 분류 제목 글쓴이 날짜 조회 수
166 Linux <주의> 생성한 DB볼륨을 절대! 삭제하지 말자 큐브리드_김주현 2019.09.30 1609
165 Install APC_Install-tools 구성 및 설치 방법 file Prototype 2009.03.13 30614
164 PHP Apache, PHP 설치 방법 file 이용미 2013.05.16 41248
163 Java AquaDataStudio 에서 CUBRID 사용하기 Prototype 2009.04.18 23667
162 Install AutoSet 4.3.2를 이용한 APACHE+PHP+CUBRID 2008 설치 가이드 seongjoon 2009.03.13 38974
161 CCI/DB API CCI-API 사용 예제 file 남재우 2009.07.01 25103
160 CCI/DB API CCI-API 에서 OID 사용 예제 file 남재우 2009.07.01 24861
159 기타 CSQL 인터프리터 사용방법 정만영 2016.03.03 16663
158 Install CUBRID 2008 + Textyle 설치 가이드 3 1 Prototype 2009.07.29 18287
157 기타 CUBRID 2008 + XE 설치 가이드 [R1.x] Prototype 2009.03.13 34326
156 기타 CUBRID 2008 + XE 설치 가이드 [R2.0] Prototype 2009.08.27 16573
155 기타 CUBRID 2008 1.x 에서 CUBRID 2.0 64bit로 Migration 3 janus 2009.08.15 15860
154 기타 CUBRID 2008 R2.0 추가 및 변경 기능 소개 janus 2009.08.15 20663
153 기타 CUBRID 2008 R2.0의 CM변경사항 janus 2009.11.20 17045
152 기타 CUBRID 2008 R3.0 추가기능 file janus 2010.09.03 15455
151 기타 CUBRID 2008 R4.0 GA 버전의 주요 기능만 요약한 PPT 문서 file admin 2011.07.14 15462
150 기타 CUBRID 2008 R4.0 파라미터 변경 사항 (일부) file admin 2011.07.14 13154
149 튜닝 CUBRID 2008 R4.0의 커버링 인덱스(covering index)는 무엇인가? file admin 2011.07.14 29883
148 Linux CUBRID 2008 사용법 admin 2008.11.21 36762
147 Windows CUBRID 2008 사용법 admin 2008.11.21 47939
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