>데이터 베이스 >MySQL 튜토리얼 >PHP에서 mysql 데이터베이스의 데이터를 삭제하는 방법

PHP에서 mysql 데이터베이스의 데이터를 삭제하는 방법

王林
王林앞으로
2023-06-02 23:45:031245검색

  1. 삭제 전 데이터베이스를 백업하세요.

삭제 전, 데이터베이스를 먼저 백업해두시는 것이 좋습니다. PostgreSQL 및 MySQL 데이터베이스 작업을 위한 일반적인 전략입니다. 다음과 같이 다시 작성할 수 있습니다: 일반적인 PostgreSQL 및 MySQL 데이터베이스 처리 전략. 실수로 데이터를 삭제한 경우 백업을 통해 데이터를 복구할 수 있습니다. phpMyAdmin 또는 명령줄 도구를 사용하여 백업을 완료할 수 있습니다. 데이터베이스를 백업하려면 명령줄에서 mysqldump 명령을 사용하십시오.

  1. DELETE 문을 사용하세요

DELETE 문을 사용하여 테이블의 데이터를 삭제하세요. DELETE 문을 사용하면 특정 행을 삭제하거나 와일드카드를 사용하여 일괄적으로 행을 삭제할 수 있습니다.

<?php
//连接到数据库
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "myDB";

//创建连接对象
$conn = new mysqli($servername, $username, $password, $dbname);

//检查连接
if ($conn->connect_error) {
    die("连接失败: " . $conn->connect_error);
}

//编写删除数据的SQL语句
$sql = "DELETE FROM myTable WHERE id=1";

//执行SQL语句
if ($conn->query($sql) === TRUE) {
    echo "数据删除成功";
} else {
    echo "删除失败: " . $conn->error;
}

//关闭连接
$conn->close();
?>

위 코드에서는 DELETE 문을 사용하여 myTable 테이블에서 ID 1의 행을 삭제합니다. 행이 성공적으로 삭제되면 프로그램은 "데이터 삭제 성공"을 출력하고, 삭제되지 않으면 프로그램은 "삭제 실패"를 출력하고 MySQL에서 오류 메시지를 반환합니다.

  1. SQL 주입 공격 방지

SQL 주입 공격은 애플리케이션 데이터 유출을 유발할 수 있는 일종의 사이버 공격입니다. SQL 주입 공격을 피하기 위해 PHP의 mysql_real_escape_string() 함수를 사용하여 사용자가 입력한 데이터를 이스케이프할 수 있습니다.

<?php
//连接到数据库
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "myDB";

//创建连接对象
$conn = new mysqli($servername, $username, $password, $dbname);

//检查连接
if ($conn->connect_error) {
    die("连接失败: " . $conn->connect_error);
}

//获取用户输入的数据
$id = $_POST[&#39;id&#39;];

//使用mysql_real_escape_string()函数转义用户输入的数据
$id = mysql_real_escape_string($id);

//编写删除数据的SQL语句
$sql = "DELETE FROM myTable WHERE id=&#39;$id&#39;";

//执行SQL语句
if ($conn->query($sql) === TRUE) {
    echo "数据删除成功";
} else {
    echo "删除失败: " . $conn->error;
}

//关闭连接
$conn->close();
?>

위 코드에서는 SQL 주입 공격을 방지하기 위해 mysql_real_escape_string() 함수를 사용하여 사용자가 입력한 데이터를 이스케이프 처리합니다.

  1. 트랜잭션 관리를 사용하여 작업 삭제

트랜잭션 관리는 여러 테이블의 데이터를 삭제해야 할 때 매우 중요합니다. PHP에서는 MySQLi 또는 PDO 확장을 사용하여 트랜잭션 기반 삭제를 수행할 수 있습니다.

<?php
//连接到数据库
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "myDB";

//创建连接对象
$conn = new mysqli($servername, $username, $password, $dbname);

//检查连接
if ($conn->connect_error) {
    die("连接失败: " . $conn->connect_error);
}

//开启事务
$conn->begin_transaction();

//编写删除数据的SQL语句
$sql1 = "DELETE FROM myTable WHERE id=1;";
$sql2 = "DELETE FROM myTable1 WHERE id=2;";

//删除数据
if ($conn->query($sql1) === TRUE && $conn->query($sql2) === TRUE) {
    //提交事务
    $conn->commit();
    echo "所有数据删除成功";
} else {
    echo "删除失败: " . $conn->error;
    //回滚事务,撤销删除操作
    $conn->rollback();
}

//关闭连接
$conn->close();
?>

위 코드에서는 Begin_transaction() 함수를 사용하여 트랜잭션을 시작하고, 마지막에 commit() 함수를 사용하여 결과를 제출합니다. 오류가 발생하면 Rollback() 함수를 사용하여 이전 삭제 작업을 취소할 수 있습니다.

위 내용은 PHP에서 mysql 데이터베이스의 데이터를 삭제하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 yisu.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제