
mysqli_sql_exception::getSqlState 함수는 MySQL 서버에서 발생한 오류를 식별하는 데 사용됩니다. 이 함수는 오류의 원인을 파악하는 데 도움이 됩니다.
SQL 상태 코드는 표준화된 코드로, 오류의 종류를 나타냅니다. 예를 들어, 42000은 일반 오류를 나타내고, 42001은 트랜잭션 관련 오류를 나타냅니다.
SQL 상태 코드를 해석하는 방법은 다음과 같습니다.
- 42000: 일반 오류 (예: 데이터베이스에 접근할 수 없음)
- 42001: 트랜잭션 관련 오류 (예: 트랜잭션을 롤백할 수 없음)
- 42002: 트랜잭션 관련 오류 (예: 트랜잭션을 커밋할 수 없음)
- 42003: 트랜잭션 관련 오류 (예: 트랜잭션을 롤백할 수 없음)
mysqli_sql_exception::getSqlState 함수를 사용하여 오류를 처리하는 방법은 다음과 같습니다.
- 오류가 발생했을 때, 데이터베이스에 다시 접근할 수 있습니다. 예를 들어, 오류가 데이터베이스에 대한 접근 권한 문제인 경우, 데이터베이스에 다시 접근할 수 있습니다.
- 오류를 무시할 수 없습니다. 예를 들어, 오류가 데이터베이스 자체의 문제인 경우, 오류를 무시할 수 없습니다.
예시를 통해 mysqli_sql_exception::getSqlState 함수를 사용하여 오류를 처리하는 방법을 보여드리겠습니다.
#hostingforum.kr
php
try {
$mysqli = new mysqli("localhost", "username", "password", "database");
$mysqli->query("SELECT * FROM table");
} catch (mysqli_sql_exception $e) {
if ($e->getSqlState() == "42000") {
// 데이터베이스에 접근할 수 없음
echo "데이터베이스에 접근할 수 없습니다.";
} elseif ($e->getSqlState() == "42001") {
// 트랜잭션 관련 오류
echo "트랜잭션 관련 오류입니다.";
} else {
// 다른 오류
echo "다른 오류입니다.";
}
}
이 코드는 데이터베이스에 접근하는 데 실패했을 때, SQL 상태 코드를 반환하고 오류를 처리하는 방법을 보여줍니다.
2025-07-22 01:21