개발자 Q&A

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

2025.04.19 22:08

SQLSRV_BEGIN_TRANSACTION 관련 질문

목록
  • SCSS연구가 4일 전 2025.04.19 22:08
  • 5
    1
제가 현재 MSSQL 서버와 PHP를 이용하여 데이터베이스 연동을 진행 중인데,
SQLSRV_BEGIN_TRANSACTION 함수를 사용하여 트랜잭션을 시작할 때,
트랜잭션을 시작하기 전 SQLSRV_ERR_NO_TRANSACTION 오류가 발생하는 현상을 보았습니다.

이러한 오류는 어떻게 해결할 수 있는지 여기에 알려주신다면 감사하겠습니다.

    댓글목록

    profile_image
    나우호스팅  4일 전



    SQLSRV_BEGIN_TRANSACTION 함수를 사용하여 트랜잭션을 시작하기 전에 발생하는 SQLSRV_ERR_NO_TRANSACTION 오류는, 트랜잭션을 시작하기 전에 커밋 또는 롤백이 이미 수행된 경우에 발생합니다.

    이러한 오류를 해결하기 위해서는, 트랜잭션을 시작하기 전에 커밋 또는 롤백을 수행하지 않은 상태에서 SQLSRV_BEGIN_TRANSACTION 함수를 호출해야 합니다.

    트랜잭션을 시작하기 전에 커밋 또는 롤백을 수행하지 않은 상태를 확인하기 위해, SQLSRV_ERR_NO_TRANSACTION 오류가 발생하기 전에 SQLSRV_ERR_NO_TRANSACTION 오류를 확인하는 코드를 추가할 수 있습니다.

    예를 들어, 다음 코드를 사용할 수 있습니다.

    #hostingforum.kr
    php
    
    $connection = sqlsrv_connect('서버 이름', '사용자 이름', '비밀번호');
    
    if ($connection === false) {
    
        die('연결 실패');
    
    }
    
    
    
    // 트랜잭션을 시작하기 전에 커밋 또는 롤백이 이미 수행되지 않은지 확인합니다.
    
    if (sqlsrv_errcode($connection) == SQLSRV_ERR_NO_TRANSACTION) {
    
        // 트랜잭션을 시작할 수 있습니다.
    
        sqlsrv_begin_transaction($connection);
    
    } else {
    
        // 트랜잭션을 시작할 수 없습니다.
    
        die('트랜잭션을 시작할 수 없습니다.');
    
    }
    
    
    
    // 트랜잭션을 수행합니다.
    
    // ...
    
    
    
    // 트랜잭션을 커밋합니다.
    
    sqlsrv_commit($connection);
    
    


    이러한 코드를 사용하면, 트랜잭션을 시작하기 전에 커밋 또는 롤백이 이미 수행되지 않은 상태에서 트랜잭션을 시작할 수 있습니다.

    2025-04-19 22:09

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

검색

게시물 검색