Search Results for '아름다운개발'

381 POSTS

  1. 2007.08.30 모든 민족과 열방들 가운데
  2. 2007.08.29 네이버 블로그 에러... 2
  3. 2007.08.24 iBatis에서 insert된 자동생성값 알아오기 - MySQL버전

모든 민족과 열방들 가운데

Posted 2007. 8. 30. 00:34


 

'ccm & 악보' 카테고리의 다른 글

[악보+찬양]너는 내 아들이라  (0) 2007.10.20
주님다시 오실때까지  (0) 2007.10.06
주이름 찬양  (0) 2007.09.16
뒤돌아 서지 않겠네  (0) 2007.08.30
북한의 기독교인들의 현주소입니다.  (0) 2007.08.14


네이버 블로그 에러...

Posted 2007. 8. 29. 11:17
음.... 오늘 아침 블로그 들어가서 글을 수정하는데 저장을 누르니 화면 이동이 안된다.
혹시나 해서 목록을 클릭하여 해당 글을 보니 정상적으로 수정 반영은 되었다.
그리고 새로운 글을 쓸려고 하니 에러... 이런..

사용자 삽입 이미지


사용자 삽입 이미지


사용자 삽입 이미지


사용자 삽입 이미지

사용자 삽입 이미지



오라클을 사용하여 프로그램할땐 Sequence의 nextVal을 이용하여 insert하고 해당 값으로 관련된 다른 테이블에 사용하곤 했었는데...
MySQL이나 MSSQL은 auto_increment, identity를 이용하여 디비 내부적으로 자동증가하여 그 부분을 어떻게 처리할까 고민하곤 했었다. 내부적으로 SCOPE_IDENTITY(), LAST_INSERT_ID() 함수를 이용하여 가져올수 있다는 것을 나중에서야 알았따.

이제 본론으로.... iBatis를 이용할때 이부분 더 좋게 지원해준다.
<selectKey>를 이용하면 프로그램쪽에서 한번더 select하는 번거로움을 덜어주고 성능면에서도 조금은 도움을 줄것으로 생각된다.

* 키값이 자동증가인 경우 ...
<insert id="insertId">
  insert into MEMBER (MBR_ID, NAME) values
    ( #mbrId#, #name# )
  <selectKey keyProperty="memberSeq" resultClass="int">
    SELECT  LAST_INSERT_ID()
  </selectKey>
</insert>
Integer result = sqlMap.insert("insertId", member);

이렇게 처리하면 result에 마지막으로 추가된 키값이 담기게 된다.

* 키값이 자동증가가 아닌경우...

<insert id="insertId">
  <selectKey keyProperty="memberSeq" resultClass="int">
    SELECT MAX(MBR_SEQ) + 1 FROM MEMBER
  </selectKey>
  insert into MEMBER (MBR_SEQ, MBR_ID, NAME) values
    ( #memberSeq#, #mbrId#, #name# )
  <selectKey keyProperty="memberSeq" resultClass="int">
    SELECT  LAST_INSERT_ID()
  </selectKey>
</insert>

이와 같이 처리하면 끝.


« PREV : 1 : ··· : 119 : 120 : 121 : 122 : 123 : 124 : 125 : ··· : 127 : NEXT »