Heim > Backend-Entwicklung > PHP-Tutorial > Wie kann ich mit PDO in PHP eine ähnliche Funktionalität wie MySQLs „mysql_fetch_array' erreichen?

Wie kann ich mit PDO in PHP eine ähnliche Funktionalität wie MySQLs „mysql_fetch_array' erreichen?

DDD
Freigeben: 2024-12-15 03:52:09
Original
379 Leute haben es durchsucht

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

Verwenden von PDO zum Abrufen von Ergebnisarrays in PHP

Um SQL-Injection-Schwachstellen zu mindern, möchten Sie PDO anstelle von regulärem verwenden MySQL-Verbindungen. Wenn Sie sich fragen, ob Ihr PDO-Skript eine ähnliche Funktionalität wie Ihr vorheriges MySQL-Skript bietet, stehen Sie vor einem Dilemma.

Originalskripte:

PDO-Skript:

$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);
Nach dem Login kopieren

Reguläres MySQL Skript:

$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);
Nach dem Login kopieren

PDO-Abruffunktionalität

Um eine ähnliche Funktionalität wie die While-Schleife zu erreichen, die Sie mit Ihrem regulären MySQL-Skript verwendet haben, können Sie das PDOStatement verwenden .fetchAll-Methode. So geht's:

$sth = $dbh->prepare("SELECT name, colour FROM fruit");
$sth->execute();
$result = $sth->fetchAll(\PDO::FETCH_ASSOC);
Nach dem Login kopieren

Ergebnisarray:

Dies gibt ein Array assoziativer Arrays zurück, wobei jedes Unterarray eine Zeile aus der Ergebnismenge enthält. Das folgende Codebeispiel würde beispielsweise die folgende Ausgabe erzeugen:

print_r($result);
Nach dem Login kopieren

Ausgabe:

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

    [1] => Array
        (
            [NAME] => watermelon
            [COLOUR] => pink
        )
)
Nach dem Login kopieren

Diese Array-Struktur ermöglicht Ihnen den bequemen Zugriff auf die Daten jeder Zeile und gewährleistet so eine vergleichbare Funktionalität zu Ihrem vorherigen MySQL-Skript.

Das obige ist der detaillierte Inhalt vonWie kann ich mit PDO in PHP eine ähnliche Funktionalität wie MySQLs „mysql_fetch_array' erreichen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage