Mybatis ResultMap 그리고 select

 

 

아 .. 정말

Mybatis 기똥 찼다..


필자는

어떠한 사이트를 처음 혼자 개발 하고 있다.

HTML, CSS, Controller, DB, Scirpt, 웹디 까지전부..

좀 사이즈가 크다 보니 .. 

쿨럭 ..

게다가 처음인지라

점점 복잡해 져가는 로직 에

DB가 문제가 되었다. 

단일 테이블 조회는 상관이 없었지만

여러 테이블 동시에 4개 조인( 너무 정규화를 시켜도 문제다.. 조인이 너무 많아진다. )

을 하다보니

1 : N : M : 1 : 1 연결 에서

결과값이 List로 불러 오니.

Controller 단에서 어떻게 처리를 해야 할지.

괜히 메모리만 잡아 먹는 느낌이 들었다 .

그리고 무분별한 조인으로 DB에 영향이 갈가 걱정되기도 했다

예를 들어 난

Object  를 불러 오고 싶었는데 조인을 하다보니 Object가 아닌 Object List가 불러 오는 경우였다.. 

무슨 말이냐면

project {
   private String value1
   private String value2
   private Process value3
}

porcess {
   private String proc1
   private String proc2
   private String proc3 
   private Step proc4
}
Step {
  private String step1
  private String step2
}

이런식에 DTO가 있을시
DB에조인을 해서 이러한 연관 관계를 어떻게

잘 ~ 이쁘게 넣느냐 가 나의 관점이었다. 

결국 뻘짓과 삽질에 반복으로 해결할 수 있었다.
바로 ResultMap 과 association , collection 의 조화 였다. 아..

아름다워라

이제 서로 닥치고 본론으로 가겠다.

<select id="getProject" resultMap="ProjectMaxAll" parameterType="string">
  select
   prj_name, prj_desc, prj_start,
   proc_idx, max(proc_step) as proc_step, proc_memo, proc_expire, proc_regdate
  from
   project
  left join process on prj_name = proc_prj_name
  where
   prj_name = #{prj_name}
 </select>


 <!-- 프로세스 , 속한 고객정보 가져오기 -->
 <select id ="getProcess" resultMap="ProcessAll" parameterType="string">
  select
   proc_idx, proc_step, proc_memo, proc_expire, proc_regdate
  from
   process
  where
   proc_idx = #{proc_idx}
 </select>
<!--  프로젝트의 프로세스 단계 리스트  -->
 <select id="procStepList"  resultType="Step" >
  select
   step_idx, step_cust_idx, cust_name, comp_name, cust_cellphone
  from
   step_company
  left join customer
   on step_cust_idx = cust_idx
  left join company
   on cust_comp_idx = comp_idx
  where
   step_proc_idx = #{proc_idx}
 </select>
 
 <!--  프로세스의 고객 정보 리스트 -->
 <select id="StepList"  resultType="StepLevel" >
  select
   proc_idx as step_proc_idx, step_title
  from process
   left join step on step_value = proc_step
  where
   proc_prj_name = #{proc_prj_name}
 </select>


 <resultMap id="ProjectMaxAll" type="Project" >
  <id property="prj_name" column="prj_name"/>
  <result property="prj_desc" column="prj_desc"/>
  <result property="prj_start" column="prj_start"/>
  <!-- 프로세스 목록 조회 ProcessAll -->
  <association property="proc" column ="proc_idx" javaType="PrjProcess" resultMap="ProcessAll"/>
 
  <!-- 프로젝트 프로세스 목록 조회 -->
  <association property="stepLevel" column ="prj_name" javaType="ArrayList"
  select="StepList">
   <id property="step_proc_idx" column="step_proc_idx" />
   <result property="step_title" column="step_title" />
  </association>
 </resultMap>
 
 <!-- 프로세스 조회  시작 -->
 <resultMap id="ProcessAll" type="PrjProcess" >
   <id property="proc_idx" column="proc_idx"/>
   <result property="proc_step" column="proc_step"/>
   <result property="proc_memo" column="proc_memo"/>
   <result property="proc_expire" column="proc_expire" />
   <result property="proc_regdate" column="proc_regdate" /> 
   <!-- Step Company 조회 -->
   <association property="prj_proc_stepList"  column="proc_idx" javaType="ArrayList"
    select="procStepList">
    <id property="step_idx" column="step_idx" />
    <result property="step_cust_idx" column="step_cust_idx" />
    <result property="cust_name" column="cust_name" />
    <result property="comp_name" column="comp_name" />
    <result property="cust_cellphone" column="cust_cellphone" /> 
    
   </association> 
 </resultMap>


복잡한가? 실로 그러치 않더라.

정말 이번걸 보면서 DTO가 얼마나 중요한지 깨달았다. 

처음에 하나에 DTO다 때려 넣었다가.

이렇게도 된다는 점이 너무 행복했다.

그리고 이렇게 가지고 온 값을

쉽게 뿌릴 수 있는 Spring Form 태그에 감사한다.

경축! 아무것도 안하여 에스천사게임즈가 새로운 모습으로 재오픈 하였습니다.
어린이용이며, 설치가 필요없는 브라우저 게임입니다.
https://s1004games.com

 

[출처] http://pikasoo.egloos.com/502488

 

 

 

본 웹사이트는 광고를 포함하고 있습니다.
광고 클릭에서 발생하는 수익금은 모두 웹사이트 서버의 유지 및 관리, 그리고 기술 콘텐츠 향상을 위해 쓰여집니다.
번호 제목 글쓴이 날짜 조회 수
184 jsoup을 활용해서 Java에서 HTML 파싱하는 방법 정리 file 졸리운_곰 2017.03.04 157
183 Java Naming conventions 자바 명명 규칙 졸리운_곰 2017.03.04 74
182 NSA의 Dataflow 엔진 Apache NiFi 소개와 설치 file 졸리운_곰 2017.01.23 463
181 wordpress-java-integration 자바와 워드프레스 통합 졸리운_곰 2016.12.30 166
180 XQuery를 이용한 Screen-Scraping file 졸리운_곰 2016.11.29 168
179 Getting Started with Custom Deserialization in Jackson 졸리운_곰 2016.11.18 168
178 how to parse json array value using json node 졸리운_곰 2016.11.17 60
177 How to convert Java object to / from JSON (Jackson) 졸리운_곰 2016.11.16 78
176 Create New Posts in Wordpress using Java and XMLRpc 졸리운_곰 2016.11.14 69
175 자바로 POST 방식으로 통신하기, java httppost 클래스를 활용한 예제 졸리운_곰 2016.11.14 444
174 [Java]아파치 HttpClient사용하기 file 졸리운_곰 2016.11.14 104
173 Timer 클래스를 이용한 작업 스케쥴링 졸리운_곰 2016.11.14 97
172 SQLite Java Tutorial 졸리운_곰 2016.08.11 84
171 numerical analysis with java examples - turhancoban.com.pdf file 졸리운_곰 2016.06.07 263
170 MyBatis 기본 - selectList file 졸리운_곰 2016.06.07 292
» Mybatis ResultMap 그리고 select 졸리운_곰 2016.06.07 267
168 Mybatis selectList 예제 졸리운_곰 2016.06.05 448
167 java 에서 mybatis 사용한 예제 file 졸리운_곰 2016.06.05 462
166 [Mybatis] 간단한 마이바티스 CRUD 예제 file 졸리운_곰 2016.06.05 273
165 자바 8 살펴보기 file 졸리운_곰 2016.05.23 277
대표 김성준 주소 : 경기 용인 분당수지 U타워 등록번호 : 142-07-27414
통신판매업 신고 : 제2012-용인수지-0185호 출판업 신고 : 수지구청 제 123호 개인정보보호최고책임자 : 김성준 sjkim70@stechstar.com
대표전화 : 010-4589-2193 [fax] 02-6280-1294 COPYRIGHT(C) stechstar.com ALL RIGHTS RESERVED