Heim > Datenbank > MySQL-Tutorial > Hauptteil

Wie erstelle ich dynamisch PHP-Objekte aus MySQL-Strings?

Linda Hamilton
Freigeben: 2024-11-14 19:11:02
Original
453 Leute haben es durchsucht

How to Dynamically Create PHP Objects from MySQL Strings?

Dynamische Objekterstellung in PHP aus MySQL-String

Viele Anwendungen speichern Informationen über Objekte in einer Datenbank. Das Problem ist: Wie stellt man diese Daten im PHP-Code dar? Object-Relational Mapping (ORM)-Frameworks können hilfreich sein, sie können jedoch komplex sein und sind möglicherweise nicht immer notwendig.

Diese Antwort stellt eine einfache Lösung dar, um PHP-Objekte dynamisch auf der Grundlage von in einer MySQL-Datenbank gespeicherten Zeichenfolgen zu erstellen.

Das Problem:

Gegeben sei eine MySQL-Tabelle mit dem folgenden Schema:

id | type | propertyVal
----+------+-------------
1 | foo | lorum
2 | bar | ipsum
Nach dem Login kopieren

wobei id der eindeutige Bezeichner und type der Objekttyp ist (z. B. foo, bar) und propertyVal ist ein Eigenschaftswert.

Die Aufgabe besteht darin, PHP-Objekte der in der Typspalte definierten dynamischen Typen zu erstellen und sie mit den Daten aus der entsprechenden Zeile in der Tabelle zu füllen .

Die Lösung:

In PHP können Sie ein Objekt eines bestimmten Typs dynamisch erstellen, indem Sie die folgende Syntax verwenden:

$type = 'myClass';

$instance = new $type;
Nach dem Login kopieren

Angenommen Wenn die Abfrage ein assoziatives Array zurückgibt, können Sie dem Objekt mithilfe einer ähnlichen Syntax Eigenschaften zuweisen:

foreach ($row as $property => $value) {
   $instance->$property = $value;
}
Nach dem Login kopieren

Implementierung:

  1. Zeilendaten abrufen von die Datenbank mithilfe einer Abfrage.
  2. Rufen Sie den Typwert aus der Zeile ab.
  3. Erstellen Sie eine Instanz dieses Typs mit dem neuen $type.
  4. Entfernen Sie den Typschlüssel aus der Zeile um das Festlegen der Typeigenschaft der Instanz zu vermeiden.
  5. Iterieren Sie die verbleibenden Schlüssel und Werte in der Zeile und weisen Sie sie den entsprechenden Eigenschaften des Objekts zu.

Beispiel :

$row = $result->fetch_assoc();

$type = $row['type'];
unset($row['type']);

$instance = new $type;

foreach ($row as $property => $value) {
   $instance->$property = $value;
}
Nach dem Login kopieren

Mit diesem Ansatz können Sie dynamische Objekte aus einer Datenbank erstellen, ohne dass komplexe ORM-Frameworks erforderlich sind. Es ist eine einfache und effektive Lösung für viele Szenarien, in denen Sie Datenbankdaten als dynamische Objekte in Ihrem PHP-Code darstellen müssen.

Das obige ist der detaillierte Inhalt vonWie erstelle ich dynamisch PHP-Objekte aus MySQL-Strings?. 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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage