IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Symfony PHP Discussion :

__toString() et performances


Sujet :

Symfony PHP

  1. #1
    Membre averti
    Homme Profil pro
    Webmaster
    Inscrit en
    Août 2006
    Messages
    55
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Webmaster
    Secteur : Santé

    Informations forums :
    Inscription : Août 2006
    Messages : 55
    Par défaut __toString() et performances
    Bonjour,

    Dans le cadre de l'affichage d'un formulaire assez simple au final, les références entre tables me permettent d'avoir facilement le rendu voulu (grâce aux __toString() notamment et aux sfDoctrineWidgetChoice()). Par contre, je me retrouve avec une page à 425 requêtes SQL et 15 358 ms de temps d'affichage. Ce qui est intolérable pour d'évidentes raisons de performances. D'autant qu'on pourrait facilement réduire à une dizaine de requêtes maximum en utilisant les jointures appropriées.

    Du coup, me rappelant la configuration des modules d'administration de symfony, je me demandais s'il n'y avait pas moyen de modifier le comportement de la requête lié à __toString() pour lui inclure des jointures.

    Pour référence, voici mon schema.yml :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    CopisimEtudiant:
      actAs:
        Timestampable: ~
      columns:
        nom: { type: string(50), notnull: true }
        prenom: { type: string(50), notnull: true }
        fac: { type: integer, notnull: true }
        naissance: { type: date }
        email: { type: string(100), notnull: true }
        email_tmp: { type: string(100), notnull: true }
        anonyme: { type: boolean, notnull: true, default: 0 }
        annee: { type: enum, values: ['DCEM4', 'DCEM4 doublant', 'TCEM1'], default: 'DCEM4' }
        classement: { type: integer, notnull: true }
      relations:
        CopisimFac: { local: fac, foreign: id }
     
    CopisimFac:
    #  actAs:
      columns:
        periode: { type: integer, notnull: true }
        titre: { type: string(255), notnull: true }
      relations:
        CopisimPeriode: { local: periode, foreign: id }
     
    CopisimRegion:
      columns:
        periode: { type: integer, notnull: true }
        titre: { type: string(255), notnull: true }
      relations:
        CopisimPeriode: { local: periode, foreign: id }
     
    CopisimFiliere:
      columns:
        periode: { type: integer, notnull: true }
        ref: { type: integer, notnull: false }
        titre: { type: string(255), notnull: true }
      relations:
        CopisimPeriode: { local: periode, foreign: id }
     
    CopisimPeriode:
    #  actAs:
      columns:
        annee: { type: year, notnull: true }
        debut_choix: { type: date, notnull: true }
        fin_choix: { type: date, notnull: true }
     
    CopisimPoste:
    #  actAs:
      columns:
        periode: { type: integer, notnull: true }
        ville: { type: integer, notnull: true }
        filiere: { type: integer, notnull: true }
        total: { type: integer, notnull: true }
      relations:
        CopisimPeriode: { local: periode, foreign: id }
        CopisimRegion: { local: ville, foreign: id }
        CopisimFiliere: { local: filiere, foreign: id }
     
    CopisimChoix:
      actAs:
        Timestampable: ~
      columns:
        etudiant: { type: integer, notnull: true }
        poste: { type: integer, notnull: true }
        complement: { type: integer, notnull: true }
        ordre: { type: integer, notnull: true }
      relations:
        CopisimEtudiant: { local: etudiant, foreign: classement }
        CopisimPoste: { local: poste, foreign: id }
        CopisimFiliere: { local: complement, foreign: id }
     
    CopisimFlux:
    #  actAs:
        columns:
          periode: { type: integer, notnull: true }
          ville: { type: integer, notnull: true }
          complement: { type: integer, notnull: true }
          total: { type: integer, notnull: true }
        relations:
          CopisimPeriode: { local: periode, foreign: id }
          CopisimRegion: { local: ville, foreign: id }
          CopisimFiliere: { local: complement, foreign: id }
     
    CopisimReferent:
      columns:
        periode: { type: integer, notnull: true }
        nom: { type: string(50), notnull: true }
        email: { type: string(100), notnull: true }
        tel: { type: string(10), notnull: false }
        divers: { type: string(256), notnull: false }
        fac: { type: integer, notnull: true }
      relations:
        CopisimPeriode: { local: periode, foreign: id }
        CopisimFac: { local: fac, foreign: id }
    et CopisimPoste.class.php :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    class CopisimPoste extends BaseCopisimPoste
    {
      public function __toString()
      {
        return sprintf('%s a %s', $this->getCopisimFiliere()->getTitre(), $this->getCopisimRegion()->getTitre());
      }
    }
    La classe du formulaire et celle action n'apportent pas grand chose, donc je ne les ajoute pas.

  2. #2
    Membre averti
    Homme Profil pro
    Webmaster
    Inscrit en
    Août 2006
    Messages
    55
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Webmaster
    Secteur : Santé

    Informations forums :
    Inscription : Août 2006
    Messages : 55
    Par défaut
    Bon j'ai un début de solution en redéfinissant le formulaire. Mais la question reste posée concernant les __toString() ou une solution plus propre que la mienne.

    Ma solution : J'ai redéfini les widgets du formulaires :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    $query_poste = Doctrine::getTable('CopisimPoste')->createQuery('a')->leftJoin('a.CopisimFiliere b')->leftJoin('a.CopisimRegion c')->orderBy('b.titre asc, c.titre asc');
     
    $this->widgetSchema['poste'] = new sfWidgetFormDoctrineChoice(array(
          'model' => $this->getRelatedModelName('CopisimPoste'),
          'query' => $query_poste,
        )); 
     
    $this->validatorSchema['poste'] = new sfValidatorAnd(array(
          $this->validatorSchema['poste'],
          new sfValidatorDoctrineChoice(array(
            'model' => $this->getRelatedModelName('CopisimPoste'),
            'query' => $query_poste,
            'multiple' => 'false',
          )),
        ));
    Ça me dérange un peu de modifier la structure du formulaire pour une question de requêtes d'affichage. Mais en attendant, ça réduit l'affichage de la page à 25 requêtes SQL et 9000ms (heureusement ce n'est pas mon serveur de production :p).

  3. #3
    Expert confirmé
    Avatar de Michel Rotta
    Homme Profil pro
    DPO
    Inscrit en
    Septembre 2005
    Messages
    4 954
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : DPO
    Secteur : Distribution

    Informations forums :
    Inscription : Septembre 2005
    Messages : 4 954
    Par défaut
    Le problème ne vient probablement pas de la méthode __toString(), mais du modèle objets sous-jacent.

    Regarde lors de l'exécution, tu vas voir que tu as, dans la barre de debug, une multitude de requêtes.

    Modifie la requête à l'origine de la liste pour qu'elle inclue les tables liées, tu n'auras plus alors qu'une requête et un gains de temps appréciable.

  4. #4
    Membre averti
    Homme Profil pro
    Webmaster
    Inscrit en
    Août 2006
    Messages
    55
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Webmaster
    Secteur : Santé

    Informations forums :
    Inscription : Août 2006
    Messages : 55
    Par défaut
    Donc la bonne solution est bien la modification des widgets du formulaire pour leur ajouter une option query qui va bien ?

  5. #5
    Expert confirmé
    Avatar de Michel Rotta
    Homme Profil pro
    DPO
    Inscrit en
    Septembre 2005
    Messages
    4 954
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : DPO
    Secteur : Distribution

    Informations forums :
    Inscription : Septembre 2005
    Messages : 4 954
    Par défaut
    A mon avis, c'est la solution, un querry avec un leftjoin pour tous récupérer d'un coup.

Discussions similaires

  1. [maintenance][performance] Que faire comme maintenance ?
    Par woodwai dans le forum PostgreSQL
    Réponses: 5
    Dernier message: 06/11/2003, 15h39
  2. Performance xml
    Par MicKCanE dans le forum XML/XSL et SOAP
    Réponses: 2
    Dernier message: 07/07/2003, 06h41
  3. [ POSTGRESQL ] Problème de performance
    Par Djouls64 dans le forum PostgreSQL
    Réponses: 6
    Dernier message: 26/05/2003, 16h18
  4. [JDBC][connexion persistante] performances avec JDBC
    Par nawac dans le forum Connexion aux bases de données
    Réponses: 6
    Dernier message: 06/05/2003, 10h37
  5. performance entre 3DS, ase, asc ...
    Par amaury pouly dans le forum OpenGL
    Réponses: 3
    Dernier message: 24/03/2003, 11h41

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo