태터데스크 관리자

도움말
닫기
적용하기   첫페이지 만들기

태터데스크 메시지

저장하였습니다.


'iBATIS'에 해당되는 글 4건

  1. 2008/08/06 [iBatis] sql문 작성할때 유용한 조건문들
  2. 2008/03/12 [iBatis error] xml 설정파일의 중요성... (3)
  3. 2008/02/27 [iBatis] 다양한 쿼리문 작성하기.
  4. 2008/01/21 [iBatis] oscache 적용하기
2008/08/06 15:56

[iBatis] sql문 작성할때 유용한 조건문들

prepend – statement에 붙을 오버라이딩 가능한 SQL부분(옵션)

property – 체크되기 위한 프라퍼티(필수)


<isPropertyAvailable>
프라퍼티가 유효한지 체크(이를 테면 파라미터빈의 프라퍼티이다.)

<isNotPropertyAvailable>
프라퍼티가 유효하지 않은지 체크(이를 테면 파라미터의 프라퍼티가 아니다.)

<isNull>
프라퍼티가 null인지 체크

<isNotNull>
프라퍼티가 null이 아닌지 체크

<isEmpty>
Collection, 문자열 또는 String.valueOf() 프라퍼티가 null이거나 empty(“” or size() < 1)인지 체크

<isNotEmpty>
Collection, 문자열 또는 String.valueOf() 프라퍼티가 null이 아니거나 empty(“” or size() < 1)가 아닌지 체크.

<isNotEmpty prepend=”AND” property=”firstName” >
FIRST_NAME=#firstName#
</isNotEmpty>

Trackback 0 Comment 0
2008/03/12 11:17

[iBatis error] xml 설정파일의 중요성...

<select id="getNextQuestInfo" reslutClass="com.ooo.ooo.common.util.DataMap" parameterClass="java.util.Map">
  SELECT /* 080221 idididi table_namebo*/ /*+ index_desc(table_name table_name_pk) */
           a.qst_seq, a.qst_type, a.qst_clan, a.qst_name,
           a.qst_area, a.start_npc, a.start_level, a.before_qst_seq, a.mission,
           a.return_item, a.createdt, b.qst_name AS next_qst_name
  FROM table_name a, table_name b
  WHERE a.before_qst_seq = b.qst_seq
  <isNotNull prepend="AND" property="questSeq">
   a.qst_seq = #questSeq#
  </isNotNull>
 
 </select>

딱 저부분때문에~!!! 모든 iBatis관련 xml파일을 못읽어오고...

그 때문에... 모든 페이지가 안뜨는 상황이 일어났다... 내 참 어이없어서....

저게 머라고...-_-;;; 라고 생각하면 안되겠지??ㅋㅋㅋ
Trackback 0 Comment 3
  1. 버리 2008/03/12 15:49 address edit & del reply

    ㅋㅋ 철자가 틀렸군용~ 이런.. 저럴때 정말 허무하죠..

  2. 영근 2008/03/14 15:31 address edit & del reply

    ctrl+space 강추~ ㅎㅎ

    • 밥팅우기 2008/03/14 16:06 address edit & del

      이상하게... Ctrl + space가... xml하고 jsp하고...
      안될때가 있더라고요...

      xml은 dtd등록해줘야 한다고는 하지만... jsp는 왜 그러는지...-_-;;

2008/02/27 11:15

[iBatis] 다양한 쿼리문 작성하기.

<펌글:http://blog.paran.com/devtopia/13828096>

실무에서 SQL문을 작성하다 보면 동적인 쿼리문 작성을 작성해야 할 때가 많이 있다.

이때 지겹게 if~else if 문을 통해 아주 지저분한 소스 코드를 생성할 때가 왕왕 있게 마련이다.

이때 ibatis에서는 아주 깔금하게 구현할 수 있는 방법을 제공해 준다.

<statement id="dynamicGetAccountList" resultMap="account-result">
  select * from account
  <dynamic prepend="WHERE">
    <isNotNull prepend="AND" property="firstName">
      (acc_first_name = #firstName#
         <isNotNull prepend="OR" property="lastName">
             acc_last_name = #lastName#
         </isNotNull>
      )
    </isNotNull>

    <isNotNull prepend="AND" property="emailAddress">
      acc_email like #emailAddress#
    </isNotNull>

    <isGreaterThan prepend="AND" property="id" campareValue="0">
      acc_id = #id#
    </isGreaterThan>

  </dynamic>

  order by acc_last_name

</statement>


상황에 의존적인 위 동적 statement로 부터 각각 다른 16가지의 SQL문이 생성될 수 있다. if-else구조와 문자열 연결을 코딩하는 경우 수백라인이 필요할 수도 있다.

동적 statement를 사용하는 것은 몇몇 조건적인 태그를 추가하는 것처럼 간단하게 작성할 수 있다.


이러한 조건들에 대해 간단히 정리하면 아래와 같다.


바이너리 조건 요소-바이너리 조건 요소는 정적값 또는 다른 프로퍼티값을 위한 프로퍼티값과 비교한다. 만약 결과가 true라면 몸체부분의 SQL쿼리가 포함된다.


바이너리 조건 속성

prepend

Statement에 붙을 오버라이딩 가능한 SQL부분(옵션)

property

비교되는 property(필수)

compareProperty

비교되는 다른 property (필수 또는 compareValue)

compareValue

비교되는 값(필수 또는 compareProperty)


<isEqual>

프로퍼티가 값 또는 다른 프로퍼티가 같은지 체크

<isNotEqual>

프로퍼티가 값 또는 다른 프로퍼티가 같지 않은지 체크

<isGreaterThan>

프로퍼티가 값 또는 다른 프로퍼티 보다 큰지 체크

<isGreaterEqual>

프로퍼티가 값 또는 다른 프로퍼티 보다 크거나 같은지 체크

<isLessThan>

프로퍼티가 값 또는 다른 프로퍼티 보다 작은지 체크

<isLessEqual>

프로퍼티가 값 또는 다른 프로퍼티 보다 작거나 같은지 체크


사용법 예제)

<isLessEqual prepend="AND" property="age" compareValue="18">

  ADOLESCENT = 'TRUE'

</isLessEqual>


단일 조건 요소-단일 조건 요소는 특수한 조건을 위해 프로퍼티의 상태를 체크한다.

prepend

statement에 붙을 오버라이딩 가능한 SQL부분(옵션)

property

체크하기 위한 프로퍼티(필수)

 

<isPropertyAvailable>

프로퍼티가 유효한지 체크

(이를 테면 파라미터의 프로퍼티이다.)

<isNotPropertyAvailable>

프로퍼티가 유효하지 않은지 체크

(이를 테면 파라미터의 프로퍼티가 아니다.)

<isNull>

프로퍼티가 null인지 체크

<isNotNull>

프로퍼티가 null이 아닌지 체크

<isEmpty>

Collection, 문자열 또는 String.valueOf() 프로퍼티가 null이거나 empty(“” or size() < 1)인지 체크

<isNotEmpty>

Collection, 문자열 또는 String.valueOf() 프로퍼티가 null 이아니거나 empty(“” or size() < 1)가 아닌지 체크


사용법 예제)

<isNotEmpty prepend="AND" property="firstName">

  FIRST_NAME = #firstName#

</isNotEmpty>


다른 요소들

Parameter Present : 파라미터 객체가 존재하는지 체크

Parameter Present Attributes : prepend - the statement에 붙을 오버라이딩 가능한 SQL부분

<isParameterPresent>

파라미터 객체가 존재(not null)하는지 체크

<isNotParameterPresent>

파라미터 객체가 존재하지(null) 않는지 체크

 

사용법 예제)

<isNotParameterPresent prepend="AND">

EMPLOYEE_TYPE = 'DEFAULT'

</isNotParameterPresent>


Iterate : 이 태그는 Collection을 반복하거나 리스트내 각각을 위해 몸체 부분을 반복한다.

Iterate Attributes :

  prepend - the statement에 붙을 오버라이딩 가능한 SQL부분 (옵션)

  property - 반복되기 위한 java.util.List타입의 프로퍼티 (필수)

  open - 반복의 전체를 열기 위한 문자열, 괄호를 위해 유용하다. (옵션)

  close - 반복의 전체를 닫기 위한 문자열, 괄호를 위해 유용하다. (옵션)

  conjunction - 각각의 반복 사이에 적용되기 위한 문자열, AND 그리고 OR을 위해 유용하다. (옵션)

<iterate>

java.util.List 타입의 프로퍼티 반복


사용법 예제)

<iterate prepend="AND" property="userNameList" open="(" close=")" conjunction="OR">

username = #userNameList[]#

</iterate>


주의:iterator요소를 사용할 때 리스트 프로퍼티의 끝에 중괄호[]를 포함하는 것은 중요하다. 중괄호는 문자열처럼 리스트를 간단하게 출력함으로부터 파서를 유지하기 위해 리스트처럼 객체를 구별한다.

Trackback 0 Comment 0
2008/01/21 18:47

[iBatis] oscache 적용하기

<cacheModel type="OSCACHE" id="getTopRankingCache">
            <flushInterval minutes="5" />
</cacheModel>


<select id="getTopRanking" resultClass="com.nhn.dejava.util.DataMap" 
                                            parameterClass="java.util.Map" cacheModel="getTopRankingCache">
  <![CDATA[
    select asldkfjaslkjf;laskjdf lj;l   <<- 쿼리 쓰는 부분....
   ]]>
</select>   


5분마다 캐쉬 리프레쉬..... 

머 iBatis에선 이렇게 캐쉬를 적용한다...
Trackback 0 Comment 0