개발자 Q&A

개발하다 막혔다면? 여기서 질문하세요! 초보부터 고수까지, 함께 고민하고 해결하는 공간입니다. 누구나 자유롭게 질문하고 답변을 남겨보세요!

2025.07.19 07:19

CUBRID_insert_id에 대한 궁금증

목록
  • Terraform광신도 1일 전 2025.07.19 07:19
  • 17
    1
저는 현재 CUBRID 데이터베이스를 사용하여 INSERT 문을 실행할 때, 새로 삽입된 행의 ID를 얻는 방법에 대해 궁금합니다.

CUBRID_insert_id 함수를 사용하면 INSERT 문을 실행한 후 새로 삽입된 행의 ID를 반환합니다.

하지만 이 함수는 MySQL의 LAST_INSERT_ID 함수와 어떻게 다른지 궁금합니다.

그리고 CUBRID_insert_id 함수를 사용하는 경우, 트랜잭션 내에서 새로 삽입된 행의 ID를 얻을 수 있나요?

이러한 궁금증에 대한 답변을 부탁드립니다.

    댓글목록

    profile_image
    나우호스팅  1일 전



    CUBRID_insert_id 함수와 MySQL의 LAST_INSERT_ID 함수는 모두 새로 삽입된 행의 ID를 반환하는 함수입니다. 하지만 차이점은 있습니다. MySQL의 LAST_INSERT_ID 함수는 트랜잭션 내에서 새로 삽입된 행의 ID를 반환하지만, CUBRID_insert_id 함수는 트랜잭션 내에서 새로 삽입된 행의 ID를 반환하지 않습니다.

    트랜잭션 내에서 새로 삽입된 행의 ID를 얻으려면, CUBRID 9.0 버전 이상에서 사용하는 CUBRID_insert_id 함수 대신에 CUBRID 9.0 버전 이상에서 제공하는 SCOPE_IDENTITY 함수를 사용해야 합니다.

    SCOPE_IDENTITY 함수는 현재 트랜잭션 내에서 새로 삽입된 행의 ID를 반환합니다. 예를 들어, 다음과 같은 SQL 문을 사용할 수 있습니다.

    #hostingforum.kr
    sql
    
    BEGIN TRANSACTION;
    
    INSERT INTO 테이블명 (열1, 열2) VALUES ('값1', '값2');
    
    SELECT SCOPE_IDENTITY() AS 새로삽입된행ID;
    
    COMMIT;
    
    


    이러한 예제에서 SCOPE_IDENTITY 함수는 현재 트랜잭션 내에서 새로 삽입된 행의 ID를 반환합니다.

    2025-07-19 07:20

  • 개발자 Q&A 포인트 정책
      글쓰기
      50P
      댓글
      10P
  • 전체 37,614건 / 10 페이지

검색

게시물 검색