
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