>백엔드 개발 >PHP 튜토리얼 >SQL 주입 및 스택 오버플로를 방지하면서 MySQL에 2000개의 행을 효율적으로 삽입하려면 어떻게 해야 합니까?

SQL 주입 및 스택 오버플로를 방지하면서 MySQL에 2000개의 행을 효율적으로 삽입하려면 어떻게 해야 합니까?

Patricia Arquette
Patricia Arquette원래의
2024-12-13 10:23:10557검색

How Can I Efficiently Insert 2000 Rows into MySQL While Preventing SQL Injection and Stack Overflow?

mysqli의 효율적인 대량 삽입: SQL 삽입 및 스택 오버플로 방지

대량의 데이터를 MySQL 데이터베이스에 안전하고 효율적으로 삽입하는 것은 많은 애플리케이션에서 매우 중요합니다. 이 질문에서는 SQL 주입을 방지하면서 2000개의 행을 효과적으로 삽입하는 기술을 탐구합니다.

제공된 코드 조각은 값 배열을 반복하여 각 삽입에 대해 별도의 쿼리를 준비하고 실행합니다. SQL 주입에 대해서는 안전하지만 이 접근 방식은 비효율적일 수 있으며 스택 오버플로가 발생할 수 있습니다.

트랜잭션을 사용한 향상된 솔루션:

더 최적의 솔루션에는 MySQL 트랜잭션을 활용하는 것이 포함됩니다. 단일 트랜잭션 내에서 삽입을 그룹화함으로써 데이터베이스는 프로세스를 최적화하고 실행 시간을 크게 줄일 수 있습니다.

$array = 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");

성능 비교:

이 기술은 벤치마크 테스트에서 입증된 바와 같이 상당한 속도 향상:

  • 거래 없음: 226 초
  • 트랜잭션 포함: 2초

이는 테스트 사례에서 2배나 빠른 속도 증가를 나타냅니다.

트랜잭션을 활용하면 효율적으로 삽입할 수 있습니다. SQL 주입 보안을 유지하고 스택 오버플로를 방지하면서 데이터를 대량으로 처리합니다.

위 내용은 SQL 주입 및 스택 오버플로를 방지하면서 MySQL에 2000개의 행을 효율적으로 삽입하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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