iBatis에서 insert된 자동생성값 알아오기 - MySQL버전
Posted 2007. 8. 24. 21:26오라클을 사용하여 프로그램할땐 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>
이와 같이 처리하면 끝.
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>
이와 같이 처리하면 끝.
'개발노트 > iBatis/myBatis' 카테고리의 다른 글
dynamic iterate 기능에 대해서.. (1) | 2007.10.30 |
---|---|
iBatis를 사용하면서 자주 발생하는 에러...중 하나 (0) | 2007.10.06 |
iBatis와 전통적인 ORM과의 차이점 (0) | 2007.08.21 |
iBatis resultMap의 구조(?) (0) | 2007.08.16 |
여러개의 테이블을 조인한 결과는 어디에 담지? (0) | 2007.08.13 |
- Filed under : 개발노트/iBatis/myBatis