Heim >Backend-Entwicklung >PHP-Problem >So konvertieren Sie Abfrageergebnisse in PHP in ein Array

So konvertieren Sie Abfrageergebnisse in PHP in ein Array

PHPz
PHPzOriginal
2023-04-26 14:29:431222Durchsuche

Heute möchte ich mit Ihnen teilen, wie Sie Abfrageergebnisse in PHP in ein Array konvertieren. Bei der Webentwicklung müssen wir häufig Daten aus einer Datenbank abrufen und auf einer Webseite anzeigen. Die Verwendung von PHP und MySQL ist eine sehr häufige Wahl. Wenn wir eine Abfrage ausführen und die Ergebnisse erhalten, erhalten wir normalerweise ein Ergebnismengenobjekt, das mehrere Datensätze enthält. Um die Verarbeitung und Manipulation dieser Daten zu erleichtern, können wir sie in ein Array konvertieren.

In PHP können wir die MySQLi-Erweiterung und die PDO-Erweiterung verwenden, um eine Verbindung zur MySQL-Datenbank herzustellen. Beide Erweiterungen bieten Methoden zum Konvertieren von Abfrageergebnissen in Arrays. In diesem Artikel werde ich jede dieser beiden Methoden vorstellen.

1. Verwenden Sie die MySQL-Erweiterung, um Abfrageergebnisse in ein Array zu konvertieren.

MySQL ist die empfohlene MySQL-Datenbankerweiterung für PHP 5 und höher. Es bietet eine Reihe objektorientierter Schnittstellen, einschließlich der Verbindung zur MySQL-Datenbank, der Ausführung von SQL-Abfragen, der Verarbeitung von Ergebnissen usw. Unter diesen ist die Klasse mysqli_result ein Objekt, das die Ergebnismenge darstellt. Wir können die Ergebnismenge in ein Array konvertieren, indem wir die Methode fetch_array in der Klasse mysqli_result aufrufen. Die

fetch_array-Methode akzeptiert einen Parameter, der den Typ des zurückzugebenden Arrays angibt. Standardmäßig wird ein Array zurückgegeben, das die Nummer und den zugehörigen Index enthält. Wir können den zurückzugebenden Array-Typ angeben, indem wir die Konstanten MYSQLI_ASSOC, MYSQLI_NUM oder MYSQLI_BOTH in den übergebenen Parametern verwenden.

Hier ist ein Beispiel:

// 连接数据库
$conn = new mysqli('localhost', 'username', 'password', 'database');

// 执行查询,获取结果集对象
$result = $conn->query('SELECT * FROM users');

// 将结果集转换为数组
$rows = $result->fetch_array(MYSQLI_ASSOC);

// 输出数组
print_r($rows);

Dieser Code gibt die erste Datenzeile in den Abfrageergebnissen aus. Wenn Sie alle Datenzeilen ausgeben möchten, können Sie eine While-Schleife verwenden.

// 连接数据库
$conn = new mysqli('localhost', 'username', 'password', 'database');

// 执行查询,获取结果集对象
$result = $conn->query('SELECT * FROM users');

// 遍历结果集,将每行数据转换为数组并输出
while ($row = $result->fetch_array(MYSQLI_ASSOC)) {
    print_r($row);
}

2. Verwenden Sie die PDO-Erweiterung, um die Abfrageergebnisse in ein Array zu konvertieren.

PDO ist eine Datenbankerweiterung, die in PHP 5.1 und höher bereitgestellt wird. Sie unterstützt eine Vielzahl von Datenbanken, einschließlich MySQL, PostgreSQL, SQLite, Oracle usw. Die PDO-Erweiterung stellt ein PDOStatement-Objekt zur Darstellung der Ergebnismenge nach der Ausführung der SQL-Abfrage bereit. Wir können die Abrufmethode im Objekt verwenden, um die Ergebnismenge in ein Array zu konvertieren. Die

fetch-Methode akzeptiert auch einen Parameter, der den Typ des zurückzugebenden Arrays angibt. Standardmäßig wird ein Array zurückgegeben, das die Nummer und den zugehörigen Index enthält. Wir können den zurückzugebenden Array-Typ angeben, indem wir die Konstanten PDO::FETCH_ASSOC, PDO::FETCH_NUM oder PDO::FETCH_BOTH in den übergebenen Parametern verwenden.

Hier ist ein Beispiel:

// 连接数据库
$dsn = 'mysql:host=localhost;dbname=database';
$username = 'username';
$password = 'password';
$conn = new PDO($dsn, $username, $password);

// 执行查询,获取 PDOStatement 对象
$stmt = $conn->query('SELECT * FROM users');

// 将结果集转换为数组
$rows = $stmt->fetch(PDO::FETCH_ASSOC);

// 输出数组
print_r($rows);

Wenn Sie alle Datenzeilen ausgeben möchten, können Sie ebenfalls eine While-Schleife verwenden:

// 连接数据库
$dsn = 'mysql:host=localhost;dbname=database';
$username = 'username';
$password = 'password';
$conn = new PDO($dsn, $username, $password);

// 执行查询,获取 PDOStatement 对象
$stmt = $conn->query('SELECT * FROM users');

// 遍历结果集,将每行数据转换为数组并输出
while ($row = $stmt->fetch(PDO::FETCH_ASSOC)) {
    print_r($row);
}

Zusammenfassung

Bis hier haben wir gelernt, wie man MySQLi- und PDO-Erweiterungen verwendet Konvertieren Sie Abfrageergebnisse in ein Array. In der tatsächlichen Entwicklung verwenden wir normalerweise Frameworks oder ORMs (wie Laravel, Doctrine usw.), um diesen Prozess zu vereinfachen. Aber das Verständnis dieser grundlegenden Implementierung ist für uns sehr wichtig, um die zugrunde liegenden Prinzipien der Webentwicklung zu verstehen. Ich hoffe, dass dieser Artikel für die Leser hilfreich sein kann.

Das obige ist der detaillierte Inhalt vonSo konvertieren Sie Abfrageergebnisse in PHP in ein Array. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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