


So verwenden Sie PHP, um eine Eins-zu-viele-Korrelationsabfrage durchzuführen
Bei der Verwendung von PHP für Datenbankoperationen ist es häufig erforderlich, Eins-zu-viele-Korrelationsabfragen durchzuführen. Diese Art von Abfrage kann ein Datenelement in einer Tabelle mit mehreren Datenelementen in einer anderen Tabelle in Beziehung setzen. In PHP führt eine relationale Eins-zu-Viele-Abfrage normalerweise zu einem zweidimensionalen Array, in dem jedes Element einen Haupttabellendatensatz darstellt und die entsprechenden Werte Datensätze in mehreren verwandten Tabellen sind.
In diesem Artikel wird erläutert, wie Sie mit PHP Eins-zu-Viele-Assoziationsabfragen durchführen und die Ergebnisse eines zweidimensionalen Arrays erhalten.
1. Was ist eine Eins-zu-viele-Abfrage?
Wenn in der Datenbank eine Primär- und Fremdschlüsselbeziehung zwischen zwei Tabellen besteht, können Sie eine Eins-zu-Viele-Zuordnungsabfrage durchführen. In dieser Beziehung entspricht ein Datensatz in einer Tabelle mehreren Datensätzen in einer anderen Tabelle.
Zum Beispiel gibt es eine „Schülertabelle“ und eine „Punktetabelle“. In der „Schülertabelle“ entspricht jeder Schüler Datensätzen in mehreren „Punktetabellen“. Diese Beziehung kann mithilfe von Primär- und Fremdschlüsseln gebunden werden, wie unten gezeigt:
CREATE TABLE `student` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(50) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `score` ( `id` int(11) NOT NULL AUTO_INCREMENT, `student_id` int(11) DEFAULT NULL, `score` int(11) DEFAULT NULL, PRIMARY KEY (`id`), KEY `student_id` (`student_id`), CONSTRAINT `score_ibfk_1` FOREIGN KEY (`student_id`) REFERENCES `student` (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
In der „Students-Tabelle“ enthält jeder Datensatz eine eindeutige Kennung ID und einen Namen NAME. In der „Score-Tabelle“ enthält jeder Datensatz dieselbe eindeutige ID und eine entsprechende STUDENT_ID, die angibt, zu welchem Schüler der Datensatz gehört. Darüber hinaus gibt es ein SCORE-Feld, das die Punktzahl des Schülers darstellt.
2. Wie führe ich eine Eins-zu-Viele-bezogene Abfrage durch?
In PHP können Sie Eins-zu-Viele-Assoziationsabfragen mithilfe des Schlüsselworts JOIN durchführen. JOIN ist ein Schlüsselwort in SQL, das verwendet wird, um dieselben Spalten in zwei oder mehr Tabellen miteinander zu verbinden und eine große Tabelle zu erstellen.
Wenn Sie im obigen Beispiel die Schülertabelle mit der Notentabelle verknüpfen möchten, können Sie die folgende SQL-Anweisung verwenden:
SELECT student.*, score.score FROM student LEFT JOIN score ON student.id = score.student_id;
Wählen Sie in dieser Anweisung den Schüler aus Zuerst alle Felder in der Tabelle und dann die Notentabelle und die Schülertabelle über die Schlüsselwörter LEFT JOIN und ON verbinden. Voraussetzung für die Verbindung ist, dass das ID-Feld in der Schülertabelle mit dem STUDENT_ID-Feld in der Notentabelle übereinstimmt. Wählen Sie abschließend mit der SELECT-Anweisung die anzuzeigenden Spalten aus und erhalten Sie das Ergebnis eines zweidimensionalen Arrays.
Im PHP-PDO-Objekt können Sie die Abfragemethode verwenden, um die obige SQL-Anweisung auszuführen, und die fetchAll-Methode verwenden, um das Ergebnis eines zweidimensionalen Arrays abzurufen:
$db = new PDO('mysql:host=localhost;dbname=mydb', 'myuser', 'mypassword'); $stmt = $db->query('SELECT student.*, score.score FROM student LEFT JOIN score ON student.id = score.student_id'); $result = $stmt->fetchAll(PDO::FETCH_ASSOC);
$data = array(); foreach ($result as $row) { $id = $row['id']; if (!isset($data[$id])) { $data[$id] = $row; $data[$id]['scores'] = array(); } if (!empty($row['score'])) { $data[$id]['scores'][] = $row['score']; } }
$db = new PDO('mysql:host=localhost;dbname=mydb', 'myuser', 'mypassword'); $stmt = $db->query('SELECT student.*, score.score FROM student LEFT JOIN score ON student.id = score.student_id'); $result = $stmt->fetchAll(PDO::FETCH_ASSOC); $data = array(); foreach ($result as $row) { $id = $row['id']; if (!isset($data[$id])) { $data[$id] = $row; $data[$id]['scores'] = array(); } if (!empty($row['score'])) { $data[$id]['scores'][] = $row['score']; } } print_r($data);
Das obige ist der detaillierte Inhalt vonSo verwenden Sie PHP, um eine Eins-zu-viele-Korrelationsabfrage durchzuführen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



Die JIT -Kompilierung von PHP 8 verbessert die Leistung, indem häufig ausgeführte Code in den Maschinencode zusammengestellt wird, um Anwendungen mit schweren Berechnungen zugute und die Ausführungszeiten zu reduzieren.

In dem Artikel wird das Sicherung von PHP -Dateien -Uploads erläutert, um Schwachstellen wie die Code -Injektion zu verhindern. Es konzentriert sich auf die Dateitypvalidierung, den sicheren Speicher und die Fehlerbehandlung, um die Anwendungssicherheit zu verbessern.

In dem Artikel werden OWASP Top 10 Schwachstellen in PHP- und Minderungsstrategien erörtert. Zu den wichtigsten Problemen gehören die Injektion, die kaputte Authentifizierung und XSS mit empfohlenen Tools zur Überwachung und Sicherung von PHP -Anwendungen.

In dem Artikel wird die symmetrische und asymmetrische Verschlüsselung in PHP erörtert und ihre Eignung, Leistung und Sicherheitsunterschiede verglichen. Die symmetrische Verschlüsselung ist schneller und für Massendaten geeignet, während asymmetrisch für den sicheren Schlüsselaustausch verwendet wird.

In dem Artikel wird die Implementierung einer robusten Authentifizierung und Autorisierung in PHP erörtert, um den nicht autorisierten Zugriff zu verhindern, Best Practices zu beschreiben und sicherheitsrelevante Tools zu empfehlen.

Vorbereitete Aussagen in PHP erhöhen die Sicherheit und Effizienz der Datenbank durch Verhinderung der SQL -Injektion und Verbesserung der Abfrageleistung durch Zusammenstellung und Wiederverwendung.

In dem Artikel werden Strategien zur Implementierung der API-Rate in PHP erörtert, einschließlich Algorithmen wie Token-Bucket und Leaky Bucket sowie Bibliotheken wie Symfony/Rate-Limiter. Es deckt auch die Überwachung, die dynamischen Einstellungsgeschwindigkeiten und die Hand ab

In dem Artikel werden die Funktionen von MySQLI_Query () und MySQLI_Fetch_assoc () in PHP für MySQL -Datenbankinteraktionen erörtert. Es erklärt ihre Rollen, Unterschiede und liefert ein praktisches Beispiel für ihre Verwendung. Das Hauptargument konzentriert sich auf die Vorteile von usin
