- 전체
- JAVA 일반
- JAVA 수학
- JAVA 그래픽
- JAVA 자료구조
- JAVA 인공지능
- JAVA 인터넷
- Java Framework
- Java GUI (AWT,SWING,SWT,JFACE)
- SWT and RCP (web RAP/RWT)[eclipse], EMF
Java Framework Mybatis ResultMap 그리고 select
2016.06.07 21:01
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 태그에 감사한다.
[출처] http://pikasoo.egloos.com/502488
광고 클릭에서 발생하는 수익금은 모두 웹사이트 서버의 유지 및 관리, 그리고 기술 콘텐츠 향상을 위해 쓰여집니다.