메뉴 건너뛰기

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

단축키

Prev이전 문서

Next다음 문서

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

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<%@ page import="com.ibatis.sqlmap.client.SqlMapClient" %>
<%@ page import="java.util.List" %>
<%@ page import="xf.common.*" %>
<%@ page import="xf.modules.sample.sampleDTO" %>
 
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<html lang="ko" xmlns="http://www.w3.org/1999/xhtml" xml:lang="ko">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<meta content="no" http-equiv="imagetoolbar"/>
<title>iBatis 동적 Connection Sample</title>
</head>
<body>
<form id="list_form" name="list_form">
<table border="1" cellspacing="0" cellpadding="0" width="100%">
  <colgroup>
    <col width="80" />
    <col width="*" />
  </colgroup>
  <thead>
    <tr>
      <th scope="col">인덱스</th>
      <th scope="col">타이틀</th>
    </tr>
  </thead>
  <tbody>
  <%
  // SqlMapConfig Connection : WEB-INF/Classes 하위 경로 부터
  // 동적으로 SqlMapConfig 로드함.
  String resource = "xf/modules/sample/SqlMapConfig.xml";
  SqlMapClient conn = SqlMapConfig(resource).getSqlMapInstance();
 
  // 아래부터는 예제로 작성됨...
  // getSample statement call
  List result = conn.queryForList("getSample",null);
  // for begin
  for(int i = 0; i < result.size(); i ++) {
    // sampleDTO bean
    sampleDTO sample = (sampleDTO) result.get(i);
    int idx = sample.getIdx();
    String title = sample.getTitle();
  %>
  <tr>
    <td><%=idx%></td>
    <td><a href="./sample.update.jsp?idx=<%=idx%>"><%=title%></a></td>
  </tr>
  <% } %>
  </tbody>
  <tfoot>
    <tr>
      <td colspan="2"><a href="./sample.insert.jsp">등록</a></td>
    </tr>
  </tfoot>
</table>
</form>
</body>
</html>


iBATIS에서 SqlMapConfig.xml 에 맵을 모두 설정하지 않고, 분할하여 관리할 수 있게 수정함.
하나의 iBatis 에서 여러 DBMS 커넥에 가능하며, 하나의 맵 오류로 인해 전체에 영향을 미치지 않게 되었다.


Java Source : SqlMapConfig.java

package xf.common;
 
/*
'// Connection
'// programmed by 최석균
'// http://syaku.tistory.com
*/
 
import java.io.Reader;

import com.ibatis.common.resources.Resources;
import com.ibatis.sqlmap.client.SqlMapClient;
import com.ibatis.sqlmap.client.SqlMapClientBuilder;

public class SqlMapConfig {
  private static final SqlMapClient sqlMap;
  private static String resource = "SqlMapConfig.xml";

  public SqlMapConfig() {
  }

  public SqlMapConfig(String resource) {
    this.resource = resource;
  }

  static {
    try {
      Reader reader = Resources.getResourceAsReader (resource);
      sqlMap = SqlMapClientBuilder.buildSqlMapClient(reader);
    } catch (Exception e) {
      e.printStackTrace();
      throw new RuntimeException ("Error initializing SqlConfig class. Cause: " + e);
    }
  }

  public static SqlMapClient getSqlMapInstance() {
    return sqlMap;
  }

}


XML Source : SqlMapConfig.xml


<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE sqlMapConfig PUBLIC "-//ibatis.apache.org//DTD SQL Map Config 2.0//EN" "http://ibatis.apache.org/dtd/sql-map-config-2.dtd">
<sqlMapConfig>
 <properties resource="SqlMapConfig.properties" />
 <settings
  cacheModelsEnabled="true"
  enhancementEnabled="true"
  lazyLoadingEnabled="true"
  maxRequests="32"
  maxSessions="10"
  maxTransactions="5"
  useStatementNamespaces="false"
 />
 <typeAlias alias="order" type="testdomain.Order"/>
 <transactionManager type="JDBC" >
  <!--
  <dataSource type="SIMPLE">
   <property name="JDBC.Driver" value="${driver}"/>
   <property name="JDBC.ConnectionURL" value="${url}"/>
   <property name="JDBC.Username" value="${username}"/>
   <property name="JDBC.Password" value="${password}"/>
  </dataSource>
  -->
     <dataSource type="JNDI">
         <property name="DataSource" value="java:${data_source_name}" />
     </dataSource>
 </transactionManager>
 
  <sqlMap resource="xf/modules/sample/sampleDAO.xml"/>
</sqlMapConfig>


Example Source




List of Articles
번호 제목 날짜 조회 수
51 인터페이스 2016.09.13 3089
50 인터페이스와 다형성 2016.09.13 3535
49 다형성 file 2016.09.13 3260
48 쓰레드의 동기화 2016.09.13 3315
47 쓰레드의 실행제어 file 2016.09.13 3266
46 데몬쓰레드 2016.09.13 3099
45 쓰레드 그룹 file 2016.09.13 3323
44 쓰레드의 우선순위 2016.09.13 3503
43 쓰레드 기본 2016.09.13 3288
42 File 클래스 file 2016.09.13 3603
41 문자 기반 스트림 2016.09.13 3440
40 바이트 기반의 스트림 file 2016.09.13 3763
39 파일I/O 개요 file 2016.09.13 3507
38 제네릭 file 2016.09.13 3297
37 컬렉션 프레임워크 file 2016.09.13 3705
36 static 2016.09.13 3354
35 클래스 메서드와 인스턴스 메서드 2016.09.13 3720
34 클래스멤버와 인스턴스멤버간의 참조와 호출 2016.09.13 3346
33 변수의 종류 2016.09.13 3980
32 JSP, Spring, GMail 메일발송 간단 예제 2016.09.12 32791
Board Pagination Prev 1 2 3 4 5 6 7 8 Next
/ 8

하단 정보를 입력할 수 있습니다

© k2s0o1d4e0s2i1g5n. All Rights Reserved