Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | ||||||
2 | 3 | 4 | 5 | 6 | 7 | 8 |
9 | 10 | 11 | 12 | 13 | 14 | 15 |
16 | 17 | 18 | 19 | 20 | 21 | 22 |
23 | 24 | 25 | 26 | 27 | 28 |
Tags
- 자바스크립트
- linux
- jquery
- 7월 공모주 청약 일정
- 주식
- MYSQL
- 자바
- Oracle
- 주식 청약
- 공모주 청약
- 6월 공모주 청약 일정
- 오라클
- Eclipse
- SQL
- 제이쿼리
- java
- 공모주 청약 일정
- codeigniter
- 리눅스
- 공모주
- Stock ipo
- 맥
- JavaScript
- 주식 청약 일정
- html
- css
- php
- IPO
- Stock
- 코드이그나이터
Archives
- Today
- Total
개발자의 끄적끄적
[iBatis] insert된 자동생성값 알아오기 - MySQL버전 본문
728x90
반응형
[iBatis] insert된 자동생성값 알아오기 - MySQL버전
오라클을 사용하여 프로그램할땐 Sequence의 nextVal을 이용하여 insert하고 해당 값으로 관련된 다른 테이블에 사용하곤 했었는데...
MySQL이나 MSSQL은 auto_increment, identity를 이용하여 디비 내부적으로 자동증가하여 그 부분을 어떻게 처리할까 고민하곤 했었다. 내부적으로 SCOPE_IDENTITY(), LAST_INSERT_ID() 함수를 이용하여 가져올수 있다는 것을 나중에서야 알았다.
이제 본론으로.... iBatis를 이용할때 이부분 더 좋게 지원해준다.
를 이용하면 프로그램쪽에서 한번더 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>
이와 같이 처리하면 끝.
반응형
'개발 > java & jsp' 카테고리의 다른 글
[java] JSP EL 변수명 동적으로 처리하는법 (0) | 2020.04.14 |
---|---|
[java] JSTL 반복문(forEach) 사용법 정리 [펌] (0) | 2020.04.13 |
[jstl] c:forEach 사용법 (0) | 2020.04.11 |
[JSP] JSTL로 특정 option selected 주기 (0) | 2020.04.10 |
[java] Map 반복(Iteration)시키는 3가지 방법 [펌] (0) | 2020.04.10 |
Comments