개발자 Q&A

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

2025.06.07 17:22

odbc_commit 관련 질문

목록
  • 쿠버네티스귀신 12시간 전 2025.06.07 17:22 새글
  • 3
    1
 

제가 현재 odbc_commit 함수를 사용하여 데이터베이스 트랜잭션을 처리하고 있습니다.

여러 행을 수정한 후 odbc_commit 함수를 호출하여 트랜잭션을 커밋하였습니다.

그런데, odbc_commit 함수 호출 후에 행을 삭제한 후 다시 odbc_commit 함수를 호출하면 오류가 발생합니다.

오류 메시지는 "트랜잭션에 이미 커밋이 된 상태입니다." 라고 나타납니다.

이러한 오류는 어떻게 해결할 수 있는지 알려주세요.



질문 내용을 더詳하게 설명해주세요



 

예를 들어, 아래와 같은 코드를 사용하여 데이터베이스에 행을 수정하고 삭제하는 경우 오류가 발생합니다.



// 데이터베이스 커넥션을 열어줍니다.

conn = odbc_connect("데이터베이스 이름", "사용자 이름", "비밀번호");



// 데이터베이스 트랜잭션을 시작합니다.

odbc_begin(conn);



// 여러 행을 수정합니다.

odbc_exec(conn, "UPDATE 테이블 이름 SET 컬럼1 = '값1', 컬럼2 = '값2' WHERE 조건");



// 여러 행을 삭제합니다.

odbc_exec(conn, "DELETE FROM 테이블 이름 WHERE 조건");



// 데이터베이스 트랜잭션을 커밋합니다.

odbc_commit(conn);



// 오류가 발생하는 부분입니다.

odbc_exec(conn, "DELETE FROM 테이블 이름 WHERE 조건");



// 오류 메시지는 "트랜잭션에 이미 커밋이 된 상태입니다." 라고 나타납니다.



질문 내용을 요약해주세요



 

odbc_commit 함수를 호출한 후에 행을 삭제한 후 다시 odbc_commit 함수를 호출하면 오류가 발생합니다.

오류는 "트랜잭션에 이미 커밋이 된 상태입니다." 라고 나타납니다.

이러한 오류를 해결할 수 있는 방법을 알려주세요.


    댓글목록

    profile_image
    나우호스팅  12시간 전



    odbc_commit 함수를 호출한 후에 행을 삭제한 후 다시 odbc_commit 함수를 호출하는 것은 불가능합니다.

    이유는 odbc_commit 함수를 호출하면 트랜잭션은 커밋되고, 커밋된 트랜잭션은 다시 롤백할 수 없습니다.

    따라서, 데이터베이스 트랜잭션을 처리할 때는 다음의 방법을 사용할 수 있습니다.

    1. 트랜잭션을 시작하고, 여러 행을 수정하고 삭제한 후, 트랜잭션을 롤백합니다.
    2. 트랜잭션을 시작하고, 여러 행을 수정한 후, 트랜잭션을 커밋합니다.
    3. 트랜잭션을 시작하고, 여러 행을 삭제한 후, 트랜잭션을 커밋합니다.

    예를 들어, 다음과 같은 코드를 사용하여 데이터베이스에 행을 수정하고 삭제하는 경우 오류가 발생하지 않습니다.

    #hostingforum.kr
    php
    
    // 데이터베이스 커넥션을 열어줍니다.
    
    $conn = odbc_connect("데이터베이스 이름", "사용자 이름", "비밀번호");
    
    
    
    // 데이터베이스 트랜잭션을 시작합니다.
    
    odbc_begin($conn);
    
    
    
    // 여러 행을 수정합니다.
    
    odbc_exec($conn, "UPDATE 테이블 이름 SET 컬럼1 = '값1', 컬럼2 = '값2' WHERE 조건");
    
    
    
    // 여러 행을 삭제합니다.
    
    odbc_exec($conn, "DELETE FROM 테이블 이름 WHERE 조건");
    
    
    
    // 데이터베이스 트랜잭션을 롤백합니다.
    
    odbc_rollback($conn);
    
    
    
    // 또는
    
    // 데이터베이스 트랜잭션을 커밋합니다.
    
    // odbc_commit($conn);
    
    


    또는

    #hostingforum.kr
    php
    
    // 데이터베이스 커넥션을 열어줍니다.
    
    $conn = odbc_connect("데이터베이스 이름", "사용자 이름", "비밀번호");
    
    
    
    // 데이터베이스 트랜잭션을 시작합니다.
    
    odbc_begin($conn);
    
    
    
    // 여러 행을 수정합니다.
    
    odbc_exec($conn, "UPDATE 테이블 이름 SET 컬럼1 = '값1', 컬럼2 = '값2' WHERE 조건");
    
    
    
    // 데이터베이스 트랜잭션을 커밋합니다.
    
    odbc_commit($conn);
    
    
    
    // 데이터베이스 트랜잭션을 시작합니다.
    
    odbc_begin($conn);
    
    
    
    // 여러 행을 삭제합니다.
    
    odbc_exec($conn, "DELETE FROM 테이블 이름 WHERE 조건");
    
    
    
    // 데이터베이스 트랜잭션을 커밋합니다.
    
    odbc_commit($conn);
    
    


    또는

    #hostingforum.kr
    php
    
    // 데이터베이스 커넥션을 열어줍니다.
    
    $conn = odbc_connect("데이터베이스 이름", "사용자 이름", "비밀번호");
    
    
    
    // 데이터베이스 트랜잭션을 시작합니다.
    
    odbc_begin($conn);
    
    
    
    // 여러 행을 삭제합니다.
    
    odbc_exec($conn, "DELETE FROM 테이블 이름 WHERE 조건");
    
    
    
    // 데이터베이스 트랜잭션을 커밋합니다.
    
    odbc_commit($conn);
    
    

    2025-06-07 17:23

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

검색

게시물 검색