Maison >base de données >tutoriel mysql >Comment créer dynamiquement des objets PHP à partir de chaînes MySQL ?

Comment créer dynamiquement des objets PHP à partir de chaînes MySQL ?

Linda Hamilton
Linda Hamiltonoriginal
2024-11-14 19:11:02517parcourir

How to Dynamically Create PHP Objects from MySQL Strings?

Création d'objets dynamiques en PHP à partir de MySQL String

De nombreuses applications stockent des informations sur les objets dans une base de données. Le problème est : comment représenter ces données dans le code PHP ? Les frameworks de mappage objet-relationnel (ORM) peuvent aider, mais ils peuvent être complexes et ne sont pas toujours nécessaires.

Cette réponse présente une solution simple pour créer dynamiquement des objets PHP basés sur des chaînes stockées dans une base de données MySQL.

Le problème :

Étant donné une table MySQL avec ce qui suit schéma :

id | type | propertyVal
----+------+-------------
1 | foo | lorum
2 | bar | ipsum

où id est l'identifiant unique, type est le type d'objet (par exemple, foo, bar) et propertyVal est une valeur de propriété.

La tâche consiste à créer PHP objets des types dynamiques définis dans la colonne type et remplissez-les avec les données de la ligne correspondante dans le tableau.

Le Solution :

En PHP, vous pouvez créer dynamiquement un objet d'un type donné en utilisant la syntaxe suivante :

$type = 'myClass';

$instance = new $type;

En supposant que la requête renvoie un tableau associatif, vous pouvez attribuer des propriétés à l'objet en utilisant un similaire syntaxe :

foreach ($row as $property => $value) {
   $instance->$property = $value;
}

Implémentation :

  1. Récupérez les données de ligne de la base de données à l'aide d'une requête.
  2. Obtenez la valeur du type à partir de la ligne.
  3. Créez une instance de ce type en utilisant new $type.
  4. Supprimez la clé de type de la ligne pour éviter de définir la propriété type de l'instance.
  5. Parcourez les clés et valeurs restantes de la ligne et attribuez-les aux propriétés correspondantes de l'objet.

Exemple :

$row = $result->fetch_assoc();

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

$instance = new $type;

foreach ($row as $property => $value) {
   $instance->$property = $value;
}

Cette approche permet de créez des objets dynamiques à partir d'une base de données sans avoir besoin de frameworks ORM complexes. C'est une solution simple et efficace pour de nombreux scénarios dans lesquels vous devez représenter les données d'une base de données sous forme d'objets dynamiques dans votre code PHP.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn