iBATIS2011. 5. 19. 18:17

1. selectKey는 오직 insert메소드에서만 사용가능하다.
 - insert메소드만이 CRUD구문에서 유일하게 Object를 반환한다.

2. selectKey는 데이터베이스에서 생성되는 키값을 삽입을 완료한 후 알고 싶을때 쓴다.

3. selectKey값의 접근법은 두가지가 있다.
 1) 레코드를 삽입하고 데이터베이스가 키를 생성한 후에 생성된 키를 가져오는것

ex) <insert id="insert">
           INSERT INTO Account ( username, password ) VALUES #username#, #password#
           <selectKey keyproperty="accountId" resultClass="int">
                SELECT SCOPE_IDENTITY()
           </selectKey>
      </insert>
  ps : SCOPE_IDENTITY() 함수는 동일한 범위(저장프로시저, 트리거, 일괄처리 등)에서 테이블에 삽입된 마지막 ID값을 반환한다.(MSSQL)

  2) 레코드를 추가하기 전에 키를 가져오는법

ex) <insert id="insertSequence">
          <selectKey keyProperty="accountId" resultClass="int">
               SELECT nextVal(#sequence#)
          </selectKey>
          INSERT INTO Account ( accountId, username, password )
          VALUES ( #accountId#, #username#, #password#)
     </insert>

이 두개의 예제는 application의 입장에서 볼때는 구문사이에 차이가 전혀 없다.
(이 예제는 첫번째 접근법에서 SCOPE_IDENTITY()를 사용해서 잠재적인 문제를 최소화한 상태다)

하지만 두개의 접근법은 예외적인 상황에서 차이가 좀 있는데
레코드를 추가하기 전에 키를 가져오는건 일반적으로 가장 안전한 방법이지만
데이터베이스에서 생성된 키를 가져오는것은 기대하는것과 다르게 작동할 수 있다는 잠재적인 문제가 있다.

책에 예로 든 내용으로는 두개의 스레드가 거의 동시에 insert구문을 실행했을때의 예를 들고 있는데
이 문제를 해결하기 위해 첫번째 방법을 사용했을때는 반환된 키값이 내가 원한 insert구문에 의해 생성된
키값인지 확인해보는것이 좋다.

아래는 여러행을 랜덤값을 넣어서 업데이트하는 예제이다.

UPDATE TBCK299 SET
TND_CD = TO_CHAR(SYSDATE, 'YYYYMMDDHH24MISS') || '_' || (select LPAD(SUBSTR(ABS(DBMS_RANDOM.RANDOM) || '', 1, 8), 8, '0') from dual)
WHERE TND_CD = #tndCd#

'iBATIS' 카테고리의 다른 글

iBatis에서 질의 작성중 $ Escape 사용법  (0) 2011.10.07
Posted by iWithJoy
Web2011. 4. 28. 18:30

호환성 모드를 제공하는데 문제는 그림에 보이는 부분을 클릭하기 전까지는 동작하지 않는다.





이와같은 불편을 해소하기 위해,
<head></head> 사이에 아래의 메타태그를 추가하면 된다.
<meta http-equiv="X-UA-Compatible" content="IE=EmulateIE7" />

또한, 서버단의 HTTP Header 수정이 가능하다면,
"X-UA-Compatible"의 헤더값으로 "IE=EmulateIE7" 을 설정하면, 본문의 메타태그 없이 호환모드로 웹페이지가 랜더링된다.

또한, IIS7.0 혹은 IIS7.5, 그 이상의 IIS버젼에 대해서 ASP.NET의 web.config에 아래처럼 코드를 구성해도 된다.
<?xml version="1.0" encoding="utf-8"?>
<configuration>
 <system.webServer> 
  <httpProtocol> 
   <customHeaders>   
    <add name="X-UA-Compatible" value="IE=EmulateIE7">
   </customHeaders>
  </httpProtocol>
 </system.webServer>
</configuration>

강제 호환모드 적용하기 안내 페이지
http://msdn.microsoft.com/ko-kr/ie/cc405106.aspx

Posted by iWithJoy
Web2011. 4. 28. 18:04

마이크로소프트사가 Internet Explorer 8 정식 버전을 내놓으면서 IE7과의 호환성에 대한 가이드라인을 공개하였다. 현재 IE8은 웹표준에 맞추어졌다는 특징이 있지만, 이것 때문에 기존 IE7의 실행에 맞추어진 일부 사이트는 IE8과의 호환성 문제가 있다. 특히, 스크립트나 CSS 문제가 가장 크다.

IE8은 이런 문제를 대처하기 위해 표준 기반의 IE8 Standards mode과 이전 브라우저와 호환성을 생각하는 Compatibility view라는 2가지 종류가 있어 IE7에 맞추어진 사이트에 그대로 이용할 수 있도록 처리하고 있다. 그러나, 호환 모드도 일부 문제가 있는 경우가 있어, 이번에 IE8에 맞춘 사이트를 위한 재검토 포인트를 마이크로소프트 개발팀에서 공개한 내용을 정리해보고자 한다.

<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" /> 

IE8 Compatibility View IE7가 다르다는 점이 가장 화두가 될 것 같다. 내가 얼마전 MSDN 세미나였던 IE8 개발자 세미나에서 질문받았던 내용 중에 IE7 호환모드로 처리하여도 똑같지 않게 나온다는 지적사항이 있었다. 실제로 마이크로소프트사에서는 새로운 기능 추가와 몇 가지 사양 변경 때문에 100% 호환성을 제공할 수 없다라는 답변을 하였다. 크게 문제가 되는 것들 것 정리해보면 다음과 같다.

 

l  Cross Document Communication

보안상 이유로 크로스 도메인/크로스 문서 통신이 사용 못한다.

해결방법: Cross Document Messaging (XDM) 사용    

l  Event Object Properties

XDM등 특정 Ajax 기능을 추가 시 IE8 새로운 속성이 추가된 문제로 인해 IE8 Compatibility View에 대한 특정 이벤트 객체로 속성명이 충돌이 난다.(source 속성 등)

event.source = myObject; // IE8 읽기전용

해결방법: 충돌나는 사용자지정 속성명을 변경한다.

event.mySource = myObject;

l  Attribute Ordering

속성의 우선 순위가 바뀌어 컬렉션이나 내외 HTML값에 영향을 받는다. 만약 속성의 순서에 의존하는 페이지가 있는 경우 정상적으로 표시되지 않는다.

attr = elm.attributes[1];

해결방법: 컬렉션 내 속성을 이름으로 명시한다.

attr = elm.attributes[“id”];

l  Unsupported CSS Values

IE버전에 의해 CSS값 지원 유무가 존재하지만 이것을 이용하여 버전을 구분하는 경우 문제가 있다.

try {

elm.style.display = “table-cell”;

} catch(e) {

// IE7 실행, IE8은 안됨

}

해결방법: CSS에 의한 버전 구분을 하지 않는다. 어려운 문제지만 만약 페이지에 이에 대한 실행이 의존적이라면 IE8 Standards Mode로 실행되도록 변경하는 것이 좋다.

IE팀 블로그 내용을 보면 IE8 Standards Mode에서는 호환성 문제가 대부분 파악된 것으로 나와 있다. 이는 기존 사이트가 IE8에 지원 대상이 아닌 경우의 기능을 이용하는 경우를 생각한 것으로 장기적인 해결책으로 보면 IE8 Standards Mode로 실행되는 사이트로 변경하는 것이 좋다라는 결론이다. 하지만 잠장적인 해결책은 IE8 IE7호환모드를 이용하는 것도 방법이며 이에 대해서는 IE 블로그의 포스팅 을 참고하여 정리해보면 주의해야 할 것들이 몇 가지 있다.

l  Version Detection

버전 구분 처리에 대한 오작동은 조건부 주석, 스크립트, 서버측에서의 처리가 원인으로 자주 발생하지만, 그 원인 대부분은 조건부 주석이며 많은 사이트에서 버전 구분 기술로서 이용되고 있다.

<!--[if IE]>

<link rel=”stylesheet” type=”text/css” src=”ie.css” />

<![endif] -->

해결방법: 정상적인 버전 구분을 할 수 있도록 사이트를 변경하던지, 가능하면 아래와 같은 오브젝트에 의한 구분 방법을 이용한다.

<!--[if lte IE 7]>

  <link rel=”stylesheet” type=”text/css” src=”ie.css” />

<![endif] -->

l  Object Detection

객체 검사를 할 때, 어느 기능 검사에 다른 기능 호출을 하는 경우, 양쪽 모두의 기능이 특정 버전으로 동시 지원하지 않으면 오작동하게 된다.

if(window.postMessage) {

window.addEventListener (

  “load”, myHnadler, false

);

}

해결방법: 코드끼리 의존관계를 없애고 알맞은 객체 검사용 코드를 추가한다.

if(window.addEventListener) {

window.addEventListener (

  “load”, myHandler, false

);

}

l  Malformed HTML

HTML문법 오류 수정방법이 IE8 Standards Mode에서 변경되고 있다. 결과적으로 IE7 실행에 의존하던 페이지는 IE8로 실행에 문제를 초래한다.

<ul>

   <li>1.1

      <ul>

         <li>1.1.1</li>

       </li>

         <li>1.1.2</li>

      </ul>

   </li>

</ul>

해결방법: 정확한 형태의 마크업 언어로 작성한다.

l  Element’s Class

IE7은 속성명으로 className을 사용하는 경우, 같은 속성의 클래스를 추출할 수 있었지만, IE8 Standards Mode에서는 표준에 맞추어진 형태로 변하고 있다. 그렇기 때문에, IE8에서는 className사용하여도 원래 결과를 얻을 수 없다.

return elm.getAttribute(“className”);

해결방법: className 대신 class 사용한다.

return elm.getAttribute(“class”);

l  GetElementById

같은 메소드는 Case Sensitive , 알파벳의 대소문자를 구별하고 있어 이름 속성을 찾지 못한다.

<div id=”Test”></div>

<script type=”text/javascript”>

var test = document.getElementById(“test”);

</script>

해결방법: 대소문자를 정확하게 구분하여 작성하며 이름속성 검색에는 getElementsByName 메소드를 사용한다.

<div id=”Test”></div>

<script type=”text/javascript”>

var test = document.getElementById(“Test”);

</script>

l  Generic CSS Prefix Selectors

CSS 구문 분석에 있어 표준에 맞춘 이유로 제네릭 CSS 프리픽스 선택기는 IE8 Standards Mode에서는 지원되지 않는다. 이것에 영향을 주는 것은 VML요소에 행동 부여 위해 페이지가 CSS를 읽어들일 때, 스크립트 오류를 발생하거나 CSS에 대한 하드코딩을 하고 있는 경우 실행이 오류가 난다. 궁극적으로는 VML이 페이지내에 표시되는 않는 등의 문제가 발생한다.

v\:* { 

    behavior:  url(#default#VML); 

}

해결방법: CSS 프리픽스 선택기를 사용하는 경우 합치고 싶은 개별 이름태그를 명시한다.

v\:polyline, 

v\:line { 

    behavior:  url(#default#VML); 

}

l  CSS Expressions

CSS Expressions IE8 Standards Mode에서는 지원되지 않는다.

/* CSS */ 

#main { 

    background-color:  expression( 

        (new Date()). getHours()%2 ?  "#000" :  "#fff" 

    ); 

}

해결방법: 강화된 CSS지원 또는 DHTML든 이용한다.

/* Script */ 

var elm = document.getElementById("main"); 

if((new Date()). getHours()%2)  { 

    elm.style.backgroundColor = "#000"; 

} else { 

    elm.style.backgroundColor = "#fff"; 

}

l  Native JSON Object

IE에서는 티브 JSON 를 지원한다. 이는 ES 3.1 Proposal Working Draft에 작성된 기준에 맞추어진 것으로 일부 페이지는 JSON객체를 인식하여 이를 비표준형태로 처리되는 경우가 있다. 이는 결과적으로 스크립트 오류를 발생하여 AJAX 요청순서를 망가트린다.

if(! window.JSON)  JSON = myJSON; 

JSON.encode(obj);  // Not part of the standard

해결방법: 비표준 문법을 사용자지정 JSON객체로 정의하던가, 표준에 맞추어진 코드로 재작성한다.

JSON = myJSON; 

JSON.encode(obj);

l  Initial CSS Property Values

currentStyle 객체로 값 설정이 되어 있지 않은 속성은 현재 각각 가지고 있는 초기값을 리턴하게 된다. 만약, z-index CSS속성이 기존 초기값 상태에 의존하고 있는 경우 문제를 발생시킨다. 이는 ASP.NET 메뉴 컨트롤의 트러블 원인이 된다.

var zIndex = elm.currentStyle.zIndex; 

if(zIndex == 0)  { 

    // custom code 

}

    해결방법: 기존과 호환성을 가지는 값과 표준에 맞추어진 초기값 양쪽 모두로 실행하도록 재

    재검토한다.

var zIndex = elm.currentStyle.zIndex; 

if(zIndex == 0 ||  zIndex == "auto")  { 

    // custom code 

}

 

l  Unspecified CSS Property Values

스타일 객체의 속성은 현재 DOM Level 2 Style Specification에 맞쳐 문자열을 리턴하게 된다.

정확하게는 정의되어 있는 않은 값을 가지는 z-index와 같은 CSS속성이 있는 경우에 문제가 발생한다.

var zIndex = elm.style.zIndex; 

if(zIndex === 0)  { 

    // custom code 

}

해결방법: 기존과 호환성을 가지는 값이나 문자열 양쪽 모두의 값으로 실행하도록 재검토한다.

var zIndex = elm.style.zIndex; 

if(zIndex === 0 ||  zIndex === "")  { 

    // custom code 

}

l  Attributes Collection

속성 컬렉션에 대해서는 모든 속성의 구성이 IE에서는 인식되는 것은 아니다. 만약 IE7에서는 존재하던 속성에 의존하는 경우, 스크립트가 오류를 발생할 가능성이 있다.

var attr = elm.attributes["checked"]; 

// Potential script error in IE8 

return attr.specified;

해결방법: 속성 컬렉션에 모든 속성이 존재한다고 생각하지 말고, 우선 그 존재유무를 확인하다.

var attr = elm.attributes["checked"]; 

if(attr) return attr.specified; 

else return false;

 

이상으로 IE팀블로그에 나온 내용을 토대로 정리해보았다. IE8이 나온지 얼마 안된 시점에서 점차 점유율이 높아지고 있는 상황에서 디자이너나 개발자들이라면 이에 대한 내용에 대해서 대처를 원활하게 처리하길 바란다.

Posted by iWithJoy
JavaScript2011. 4. 25. 17:42

ModalDialog 사용 시의 주의점

일반 팝업창이 아래와 같다면
szGroupUserSelectionURL = "javascript:popup( '" + szGroupUserSelectionURL + "', 'SelectOwnerURL', '570', '550', 'NO', 'NO');";
모달창은
szGroupUserSelectionURL = "javascript:window.showModalDialog('" + szGroupUserSelectionURL + "', self ,'dialogWidth:580px;dialogHeight:580px;scroll:0;help:0;status:0');";
이렇게 window.showModalDialog로 뛰워주면 됩니다.
 
형식은 팝업창과 거의 유사하지만 유의해야 할 점이 있습니다.
 
1. 스크립트 호출문제
모달창에서는  href="javascript:스크립트명();" 이런식으로 호출해서 쓰면 브라우저에 스크립트명이 뜨고 원하는 액션이 일어나지 않습니다.
그래서 모달창으로 뜨는 창에서 스크립트를 호출할시에는 href="#" onclick="스크립트명();" 이런식으로 쓰셔야 합니다.
 
2. 부모창 호출문제
보통 팝업창에서는 opener. 해서 쓰면 parent창이 응답을 하지만,
모달창에서는 parent를 부를 경우, child창에서는 응답하지 않습니다.
이럴땐 dialogArguments를 이용합니다. 그래서 소스를 그대로 쓰실려면
var opener = window.dialogArguments; 이렇게 선언해서 opener를 쓰시면 되겠습니다.

3. Session 전달문제
팝업창(window.open)에서는 팝업창(window.open)으로 전달 가능하고,
모달창(showModalDialog)은 모달창(showModalDialog)으로 전달 가능합니다. ("<%=Session.SessionID%>"로 확인)
showModalDialog에서 window.open하면, 새로운 창으로 인식해서 session을 공유하지 못합니다.

'JavaScript' 카테고리의 다른 글

브라우저의 각종 크기  (0) 2011.12.02
Posted by iWithJoy