>백엔드 개발 >PHP 튜토리얼 >MySQLi에 여러 행을 효율적이고 안전하게 삽입하려면 어떻게 해야 합니까?

MySQLi에 여러 행을 효율적이고 안전하게 삽입하려면 어떻게 해야 합니까?

Barbara Streisand
Barbara Streisand원래의
2024-12-31 16:12:13406검색

How Can I Efficiently and Securely Insert Multiple Rows into MySQLi?

MySQLi에서 여러 행을 효율적이고 안전하게 삽입

대규모 데이터 세트로 작업할 때 MySQL 데이터베이스에 데이터를 효율적으로 삽입하는 것이 중요합니다. 보안을 유지하면서. 이는 SQL 삽입을 방지하고 성능을 최적화하는 적절한 기술을 활용하여 달성할 수 있습니다.

여러 행을 삽입하는 효과적인 접근 방식 중 하나는 트랜잭션 내에서 준비된 문을 사용하는 것입니다. 이 방법은 데이터 무결성과 속도를 모두 보장합니다. 다음 코드 조각을 고려하십시오.

$array = ["array", "with", "about", "2000", "values"];
$query = "INSERT INTO table (link) VALUES (?)";
$stmt = $mysqli->prepare($query);
$stmt->bind_param("s", $one);

$mysqli->query("START TRANSACTION");
foreach ($array as $one) {
    $stmt->execute();
}
$stmt->close();
$mysqli->query("COMMIT");

트랜잭션을 활용하면 데이터베이스 작업이 단일 단위로 그룹화됩니다. 이는 모든 삽입이 함께 성공하거나 실패하여 데이터 일관성이 보장됨을 의미합니다. 또한 준비된 문은 모든 입력이 적절하게 삭제되도록 보장하여 SQL 주입 취약점을 방지합니다.

이 접근 방식의 또 다른 장점은 상당한 성능 향상을 제공한다는 것입니다. 데이터베이스 서버에 대한 여러 왕복을 방지함으로써 트랜잭션 접근 방식은 각 행에 대해 개별적으로 준비된 문을 사용하는 것에 비해 삽입에 필요한 시간을 획기적으로 줄입니다.

이 방법의 효율성을 설명하기 위해 다음을 실행하여 테스트를 수행했습니다. PHP 및 MySQLi를 사용하여 10,000개 삽입. 그 결과 트랜잭션을 사용할 때 놀라운 속도 증가를 보여주었습니다.

  • 트랜잭션 없음: 226초
  • 트랜잭션 있음: 2초

트랜잭션 사용 준비된 문을 결합하면 데이터 조작 공격에 대한 보안을 보장할 뿐만 아니라 MySQL 데이터베이스에 대량의 데이터를 삽입할 때 성능을 최적화할 수 있습니다.

위 내용은 MySQLi에 여러 행을 효율적이고 안전하게 삽입하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.