Heim > Datenbank > MySQL-Tutorial > Wie erstelle ich dynamisch PHP-Objekte aus MySQL-Strings?

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

Linda Hamilton
Freigeben: 2024-11-14 19:11:02
Original
514 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 Folgendem Schema:

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

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

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

Die Lösung:

In PHP können Sie mithilfe der folgenden Syntax dynamisch ein Objekt eines bestimmten Typs erstellen:

$type = 'myClass';

$instance = new $type;
Nach dem Login kopieren

Angenommen, die Abfrage gibt ein assoziatives Array zurück, können Sie Eigenschaften zuweisen zum Objekt mit einem ähnlichen Syntax:

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

Implementierung:

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

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

Dieser Ansatz ermöglicht es Ihnen Erstellen Sie dynamische Objekte aus einer Datenbank, 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