> 백엔드 개발 > PHP 튜토리얼 > PHP에서 PDO를 사용하여 MySQL의 `mysql_fetch_array`와 유사한 기능을 어떻게 얻을 수 있습니까?

PHP에서 PDO를 사용하여 MySQL의 `mysql_fetch_array`와 유사한 기능을 어떻게 얻을 수 있습니까?

DDD
풀어 주다: 2024-12-15 03:52:09
원래의
448명이 탐색했습니다.

How Can I Achieve Similar Functionality to MySQL's `mysql_fetch_array` Using PDO in PHP?

PDO를 사용하여 PHP에서 결과 배열 가져오기

SQL 주입 취약점을 완화하기 위해 일반 대신 PDO를 사용하려고 합니다. MySQL 연결. PDO 스크립트가 이전 MySQL 스크립트와 유사한 기능을 제공하는지 궁금해서 딜레마에 빠졌습니다.

원본 스크립트:

PDO 스크립트:

$pdo = new PDO('mysql:host=$host; dbname=$database;', $user, $pass);
$stmt = $pdo->prepare('SELECT * FROM auction WHERE name = :name');
$stmt->bindParam(':name', $_GET['searchdivebay']);
$stmt->execute(array(':name' => $name);
로그인 후 복사

일반 MySQL 스크립트:

$dbhost = @mysql_connect($host, $user, $pass) or die('Unable to connect to server');

@mysql_select_db('divebay') or die('Unable to select database');
$search = $_GET['searchdivebay'];
$query = trim($search);

$sql = "SELECT * FROM auction WHERE name LIKE '%" . $query . "%'";

if(!isset($query)){
    echo 'Your search was invalid';
    exit;
} //line 18

$result = mysql_query($trim);
$numrows = mysql_num_rows($result);
mysql_close($dbhost);
로그인 후 복사

PDO 가져오기 기능

일반 MySQL 스크립트에서 사용한 while 루프와 유사한 기능을 얻으려면 PDOStatement를 활용할 수 있습니다. .fetchAll 메소드. 방법은 다음과 같습니다.

$sth = $dbh->prepare("SELECT name, colour FROM fruit");
$sth->execute();
$result = $sth->fetchAll(\PDO::FETCH_ASSOC);
로그인 후 복사

결과 배열:

이는 연관 배열의 배열을 반환하며 각 하위 배열에는 결과 집합의 행이 포함됩니다. 예를 들어, 다음 코드 샘플은 다음과 같은 출력을 생성합니다.

print_r($result);
로그인 후 복사

출력:

Array
(
    [0] => Array
        (
            [NAME] => pear
            [COLOUR] => green
        )

    [1] => Array
        (
            [NAME] => watermelon
            [COLOUR] => pink
        )
)
로그인 후 복사

이 배열 구조를 사용하면 각 행의 데이터에 편리하게 액세스할 수 있으므로 비슷한 기능을 보장할 수 있습니다. 이전 MySQL 스크립트에 추가하세요.

위 내용은 PHP에서 PDO를 사용하여 MySQL의 `mysql_fetch_array`와 유사한 기능을 어떻게 얻을 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿