>백엔드 개발 >PHP 튜토리얼 >PHP MySQL을 통해 여러 데이터 조각을 삽입하는 방법

PHP MySQL을 통해 여러 데이터 조각을 삽입하는 방법

jacklove
jacklove원래의
2018-05-07 14:03:423329검색

웹사이트에서 데이터베이스에 데이터를 삽입하는 모습을 자주 볼 수 있습니다. 이 글에서는 데이터베이스에 여러 개의 데이터를 삽입하는 방법을 설명합니다.

MySQLi와 PDO를 사용하여 MySQL에 여러 데이터 조각을 삽입하세요

mysqli_multi_query() 함수를 사용하여 여러 SQL 문을 실행할 수 있습니다.

다음 예에서는 "MyGuests" 테이블에 세 개의 새 레코드를 추가합니다.

예(MySQLi - 객체 지향)

<?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 = "INSERT INTO MyGuests (firstname, lastname, email)
VALUES (&#39;John&#39;, &#39;Doe&#39;, &#39;john@example.com&#39;);";$sql .= "INSERT INTO MyGuests (firstname, lastname, email)
VALUES (&#39;Mary&#39;, &#39;Moe&#39;, &#39;mary@example.com&#39;);";$sql .= "INSERT INTO MyGuests (firstname, lastname, email)
VALUES (&#39;Julie&#39;, &#39;Dooley&#39;, &#39;julie@example.com&#39;)"; 
if ($conn->multi_query($sql) === TRUE) {
    echo "新记录插入成功";} else {
    echo "Error: " . $sql . "<br>" . $conn->error;}
 $conn->close();?>



각 SQL 문은 세미콜론으로 구분해야 합니다.

인스턴스(MySQLi - 프로시저 지향)

<?php$servername = "localhost";$username = "username";$password = "password";$dbname = "myDB"; 
// 创建链接$conn = mysqli_connect($servername, $username, $password, $dbname);// 检查链接if (!$conn) {
    die("连接失败: " . mysqli_connect_error());}
 $sql = "INSERT INTO MyGuests (firstname, lastname, email)
VALUES (&#39;John&#39;, &#39;Doe&#39;, &#39;john@example.com&#39;);";$sql .= "INSERT INTO MyGuests (firstname, lastname, email)
VALUES (&#39;Mary&#39;, &#39;Moe&#39;, &#39;mary@example.com&#39;);";$sql .= "INSERT INTO MyGuests (firstname, lastname, email)
VALUES (&#39;Julie&#39;, &#39;Dooley&#39;, &#39;julie@example.com&#39;)"; 
if (mysqli_multi_query($conn, $sql)) {
    echo "新记录插入成功";} else {
    echo "Error: " . $sql . "<br>" . mysqli_error($conn);}
 mysqli_close($conn);?>

인스턴스(PDO)

<?php$servername = "localhost";$username = "username";$password = "password";$dbname = "myDBPDO"; 
try {
    $conn = new PDO("mysql:host=$servername;dbname=$dbname", $username, $password);    // set the PDO error mode to exception
    $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); 
    // 开始事务
    $conn->beginTransaction();    // SQL 语句
    $conn->exec("INSERT INTO MyGuests (firstname, lastname, email) 
    VALUES (&#39;John&#39;, &#39;Doe&#39;, &#39;john@example.com&#39;)");    $conn->exec("INSERT INTO MyGuests (firstname, lastname, email) 
    VALUES (&#39;Mary&#39;, &#39;Moe&#39;, &#39;mary@example.com&#39;)");    $conn->exec("INSERT INTO MyGuests (firstname, lastname, email) 
    VALUES (&#39;Julie&#39;, &#39;Dooley&#39;, &#39;julie@example.com&#39;)"); 
    // 提交事务
    $conn->commit();    echo "新记录插入成功";}catch(PDOException $e){
    // 如果执行失败回滚
    $conn->rollback();    echo $sql . "<br>" . $e->getMessage();}
 $conn = null;?>

준비된 문 사용

mysqli 확장은 문을 삽입하는 두 번째 방법을 제공합니다.

문을 준비하고 매개변수를 바인딩할 수 있습니다.

mysql 확장 프로그램은 데이터 없이 mysql 데이터베이스에 명령문이나 쿼리를 보낼 수 있습니다. 변수를 네마틱하게 연관시키거나 "바인딩"할 수 있습니다.

예제(MySQLi는 준비된 문장을 사용함)

<?php$servername = "localhost";$username = "username";$password = "password";$dbname = "myDB"; 
// 创建连接$conn = new mysqli($servername, $username, $password, $dbname);// 检测连接if ($conn->connect_error) {
    die("连接失败: " . $conn->connect_error);} else {
    $sql = "INSERT INTO MyGuests(firstname, lastname, email)  VALUES(?, ?, ?)"; 
    // 为 mysqli_stmt_prepare() 初始化 statement 对象
    $stmt = mysqli_stmt_init($conn); 
    //预处理语句
    if (mysqli_stmt_prepare($stmt, $sql)) {
        // 绑定参数
        mysqli_stmt_bind_param($stmt, &#39;sss&#39;, $firstname, $lastname, $email); 
        // 设置参数并执行
        $firstname = &#39;John&#39;;        $lastname = &#39;Doe&#39;;        $email = &#39;john@example.com&#39;;        mysqli_stmt_execute($stmt); 
        $firstname = &#39;Mary&#39;;        $lastname = &#39;Moe&#39;;        $email = &#39;mary@example.com&#39;;        mysqli_stmt_execute($stmt); 
        $firstname = &#39;Julie&#39;;        $lastname = &#39;Dooley&#39;;        $email = &#39;julie@example.com&#39;;        mysqli_stmt_execute($stmt);    }}?

위의 예에서는 문제를 해결하기 위해 모듈화를 사용하는 것을 볼 수 있습니다. 코드 블록을 생성하면 읽기 및 관리가 더 쉬워집니다.

매개변수 바인딩에 주의하세요. mysqli_stmt_bind_param()의 코드를 살펴보겠습니다.

mysqli_stmt_bind_param($stmt, 'sss', $firstname, $lastname, $email);

이 함수는 매개변수 쿼리를 바인딩하고 매개변수를 데이터베이스에 전달합니다. 두 번째 매개변수는 "sss" 입니다. 다음 목록은 매개변수 유형을 보여줍니다. s 문자는 mysql에게 매개변수가 문자열임을 알려줍니다.

는 다음 네 가지 매개변수가 될 수 있습니다.

i - 정수

d - 배정밀도 부동 소수점 수

s - 문자열

b - 부울 값

각 매개변수는 데이터 보안을 보장하기 위해 유형을 지정해야 합니다. 유형 판단을 통해 SQL 주입 취약점의 위험을 줄일 수 있습니다.

이 글에서는 PHP를 통해 여러 데이터를 삽입하는 방법을 자세히 설명합니다. 더 많은 학습 자료를 보려면 PHP 중국어 웹사이트를 팔로우하세요.

관련 권장 사항:

PHP MySQL을 통해 데이터를 삽입하는 방법

PHP를 통해 MySQL 테이블을 만드는 방법

PHP MySQL을 통해 데이터베이스를 만드는 방법

위 내용은 PHP MySQL을 통해 여러 데이터 조각을 삽입하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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