
mysqli::$affected_rows는 MySQLi 객체의 메소드 중 하나로, 마지막 쿼리에서 변경된 행의 수를 반환합니다.
1. 데이터베이스에서 변경된 행의 수를 구하는 방법은 다음과 같습니다.
- MySQLi 객체를 생성한 후, 쿼리를 실행합니다.
- 쿼리 실행 후, mysqli::$affected_rows를 호출하여 변경된 행의 수를 반환합니다.
예시:
#hostingforum.kr
php
$mysqli = new mysqli("localhost", "username", "password", "database");
$mysqli->query("UPDATE table_name SET column_name = 'value' WHERE condition");
echo $mysqli->affected_rows; // 변경된 행의 수를 출력합니다.
2. mysqli::$affected_rows가 0을 반환하는 경우는 다음과 같습니다.
- 쿼리가 실행되지 않은 경우
- 쿼리가 성공적으로 실행되었지만 변경된 행이 없는 경우
- 쿼리가 실패한 경우 (예: 권한 오류, 데이터베이스 오류)
예시:
#hostingforum.kr
php
$mysqli = new mysqli("localhost", "username", "password", "database");
$mysqli->query("SELECT * FROM table_name WHERE condition"); // 쿼리가 실행되지 않음
echo $mysqli->affected_rows; // 0을 반환합니다.
$mysqli->query("UPDATE table_name SET column_name = 'value' WHERE condition = 'false'"); // 변경된 행이 없음
echo $mysqli->affected_rows; // 0을 반환합니다.
$mysqli->query("UPDATE table_name SET column_name = 'value' WHERE condition = 'invalid'"); // 권한 오류
echo $mysqli->affected_rows; // 0을 반환합니다.
3. mysqli::$affected_rows가 -1을 반환하는 경우는 다음과 같습니다.
- 쿼리가 실행되지 않은 경우 (예: 쿼리 실행 전)
- 쿼리가 실패한 경우 (예: 권한 오류, 데이터베이스 오류)
예시:
#hostingforum.kr
php
$mysqli = new mysqli("localhost", "username", "password", "database");
echo $mysqli->affected_rows; // -1을 반환합니다.
$mysqli->query("UPDATE table_name SET column_name = 'value' WHERE condition = 'invalid'"); // 권한 오류
echo $mysqli->affected_rows; // -1을 반환합니다.
2025-07-19 14:24