mysql mysql DELETE 쿼리 사용할 때 실제로 rows 삭제가 발생했는지 알 수 있는가?
2023.06.21 04:03
참고 문서 |
---|
PHP에서 MySQLi 또는 PDO를 사용하여 MySQL 데이터베이스에 접근하고 DELETE 쿼리를 실행한 후, 삭제된 행의 수를 확인할 수 있습니다. 아래에 두 가지 방법에 대한 예제를 제공하겠습니다.
MySQLi를 사용한 경우
$mysqli = new mysqli("localhost", "username", "password", "database_name");
if ($mysqli -> connect_errno) {
echo "Failed to connect to MySQL: " . $mysqli -> connect_error;
exit();
}
$query = "DELETE FROM table_name WHERE condition";
$mysqli -> query($query);
echo "Number of rows deleted: " . $mysqli -> affected_rows;
$mysqli -> close();
if ($mysqli -> connect_errno) {
echo "Failed to connect to MySQL: " . $mysqli -> connect_error;
exit();
}
$query = "DELETE FROM table_name WHERE condition";
$mysqli -> query($query);
echo "Number of rows deleted: " . $mysqli -> affected_rows;
$mysqli -> close();
PDO를 사용한 경우
try {
$pdo = new PDO('mysql:host=localhost;dbname=database_name', 'username', 'password');
$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$query = "DELETE FROM table_name WHERE condition";
$stmt = $pdo->prepare($query);
$stmt->execute();
echo "Number of rows deleted: " . $stmt->rowCount();
} catch(PDOException $e) {
echo "Error: " . $e->getMessage();
}
$pdo = null;
$pdo = new PDO('mysql:host=localhost;dbname=database_name', 'username', 'password');
$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$query = "DELETE FROM table_name WHERE condition";
$stmt = $pdo->prepare($query);
$stmt->execute();
echo "Number of rows deleted: " . $stmt->rowCount();
} catch(PDOException $e) {
echo "Error: " . $e->getMessage();
}
$pdo = null;
위 코드에서 affected_rows (MySQLi의 경우) 또는 rowCount() (PDO의 경우)가 마지막 실행된 쿼리에서 영향받은 행 수를 반환합니다. DELETE 쿼리의 경우, 이는 실제로 삭제된 행의 수를 나타냅니다.
댓글 0
번호 | 제목 | 날짜 | 조회 수 |
---|---|---|---|
» | mysql DELETE 쿼리 사용할 때 실제로 rows 삭제가 발생했는지 알 수 있는가? | 2023.06.21 | 3921 |