PHP를 사용하여 MySQL 데이터베이스와 상호 작용할 때 종종 SQL 쿼리를 수행해야합니다. 쿼리가 실패하면 올바른 오류 처리 메커니즘이 문제를 진단하고 그에 따라 처리하는 데 도움이 될 수 있습니다. MySQLI 확장자는 MySQLI_STMT :: $ 오류 및 MySQLI_STMT :: Store_Result () 메소드를 포함하여 개발자가 SQL 쿼리 오류를 포착하고 처리 할 수 있도록 몇 가지 도구를 제공합니다.
이 기사는이 두 가지 방법을 사용하여 SQL 쿼리 실패를 감지하고 처리하고 해당 PHP 샘플 코드를 표시하는 방법을 자세히 설명합니다.
SQL 쿼리를 실행할 때 MySQLI_STMT :: $ 오류는 현재 SQL 문을 실행할 때 오류 정보를 얻을 수있는 매우 유용한 속성입니다. 이 속성을 확인하면 쿼리가 성공적으로 실행되는지 신속하게 결정할 수 있습니다.
<?php
// 데이터베이스 연결
$mysqli = new mysqli("localhost", "username", "password", "database");
// 연결을 확인하십시오
if ($mysqli->connect_error) {
die("연결이 실패했습니다: " . $mysqli->connect_error);
}
// 준비하다 SQL 성명
$query = "SELECT * FROM users WHERE id = ?";
$stmt = $mysqli->prepare($query);
// 조사하다 SQL 성명是否준비하다成功
if ($stmt === false) {
die("준비하다성명失败: " . $mysqli->error);
}
// 바인딩 매개 변수
$id = 1;
$stmt->bind_param("i", $id);
// 쿼리를 실행하십시오
if (!$stmt->execute()) {
// 사용 mysqli_stmt::$error 오류 메시지를 받으십시오
die("쿼리를 실행하십시오失败: " . $stmt->error);
}
// 연결을 닫으십시오
$stmt->close();
$mysqli->close();
?>
이 예에서는 SQL 쿼리가 $ stmt-> 오류를 통해 실패 할 때 상세한 오류 정보를 얻습니다. 이러한 방식으로 개발자는 쿼리 실패의 특정 이유를 이해하고 추가 디버깅 또는 수리를 수행 할 수 있습니다.
mysqli_stmt :: store_result () 메소드는 mysqli 문 핸들에서 결과 세트를 추출하고 저장하는 데 사용됩니다. 선택 쿼리의 결과 세트를 처리하는 데 매우 유용합니다. 쿼리가 행을 반환하지 않으면 (예 : 쿼리 조건이 일치하지 않음), store_result () 메소드는 False를 반환하므로 쿼리가 데이터를 성공적으로 얻었는지 확인할 수 있습니다.
<?php
// 데이터베이스 연결
$mysqli = new mysqli("localhost", "username", "password", "database");
// 연결을 확인하십시오
if ($mysqli->connect_error) {
die("연결이 실패했습니다: " . $mysqli->connect_error);
}
// 준비하다 SQL 성명
$query = "SELECT * FROM users WHERE id = ?";
$stmt = $mysqli->prepare($query);
// 조사하다 SQL 성명是否준비하다成功
if ($stmt === false) {
die("준비하다성명失败: " . $mysqli->error);
}
// 바인딩 매개 변수
$id = 1;
$stmt->bind_param("i", $id);
// 쿼리를 실행하십시오
if (!$stmt->execute()) {
die("쿼리를 실행하십시오失败: " . $stmt->error);
}
// 저장 결과 세트
$stmt->store_result();
// 조사하다结果集的行数
if ($stmt->num_rows === 0) {
echo "기준을 충족하는 사용자는 발견되지 않았습니다。";
} else {
// 결과 세트는 비어 있지 않습니다,데이터 처리를 수행하십시오
echo "쿼리 성공,결과는 다음과 같습니다:";
// 처리 결과
}
$stmt->close();
$mysqli->close();
?>
이 예에서는 Store_result () 메소드를 사용하여 쿼리 결과를 메모리에 저장 한 다음 $ stmt-> num_rows를 사용하여 반환 된 결과 행의 수를 확인합니다. 데이터 행이 반환되지 않으면이 "결과 없음"상황을 처리 할 수 있습니다.
오류 정보를 캡처하고 결과 행 수를 확인하는 것 외에도 오류 처리를 위해 mysqli_stmt :: $ error 및 mysqli_stmt :: store_result ()를 사용하는 경우 로깅 및 디버깅을 수행 할 수도 있습니다. 일반적인 오류 처리 요령은 다음과 같습니다.
로깅 : 오류 정보를 로그 파일에 기록하여 사용자에게 직접 표시하는 대신 로그 파일로 녹화하여 데이터베이스에서 민감한 정보가 유출되지 않도록 할 수 있습니다.
사용자 친화적 인 오류 메시지 : 최종 사용자의 경우 기본 데이터베이스 오류 메시지를 노출하지 않도록 친숙한 프롬프트 정보를 제공하십시오.
SQL 쿼리 최적화 : 쿼리를 실행하기 전에 SQL 문이 유효한지 확인하고 일반적인 SQL 주입 취약점을 피하십시오.
mysqli_stmt :: $ error 및 mysqli_stmt :: store_result ()를 사용하면 SQL 쿼리 실패를 더 잘 처리하고 감지 할 수 있습니다. 실제 개발에서 좋은 오류 처리 메커니즘은 코드의 견고성을 향상시킬뿐만 아니라 생산 환경에서 문제를 신속하게 찾아서 해결하는 데 도움이 될 수 있습니다.
이 두 가지 방법의 조합을 사용하여 쿼리 실패의 세부 사항을 효과적으로 캡처하고 개발자가 쿼리 실패를 신속하게 처리 할 수 있습니다.