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

ORM PHP Discussion :

[Doctrine] chargement des données incompletes via fixtures


Sujet :

ORM PHP

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Inscrit en
    Juin 2006
    Messages
    534
    Détails du profil
    Informations forums :
    Inscription : Juin 2006
    Messages : 534
    Par défaut [Doctrine] chargement des données incompletes via fixtures
    bon mon projet commence à ressembler a quelque chose, sauf que pour tester tout ça j'ai besoin de recuperer pas mal de données de mon ancienne application.

    Du coté de l'ancien, j'ai créer des pages qui me génère mes fichiers fixtures.

    Le probleme c'est quand je les charge, a partir d'un moment il ne me prend pas tout les champs, du style, je prend le first_name, le last_name mais pas le matricule et la section.

    Déja, j'ai du modifier le database.yml pour ne plus avoir des fatal error pour dépassement de mémoire:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    all:
      doctrine:
        class: sfDoctrineDatabase
        param:
          dsn:      mysql:host=localhost;dbname=it_toolbox
          username: root
          password: xxxx
          profiler: false
    y a t il un autre moyen de charger des données avec symfony ?

    EDIT: pour info ma table sfGuardUser fait déja 700 lignes.

  2. #2
    Membre chevronné
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    396
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 396
    Par défaut
    Le fait que tu génères tes fixtures t'assure de rester dans l'environnement classique de Symfony.

    Le probleme c'est quand je les charge, a partir d'un moment il ne me prend pas tout les champs, du style, je prend le first_name, le last_name mais pas le matricule et la section.
    J'avoue que ça me paraît très bizarre ça.

    Déja, j'ai du modifier le database.yml pour ne plus avoir des fatal error pour dépassement de mémoire:
    Je ne comprends pas pourquoi toucher au databases.yml dans ce cas : n'est-ce-pas plutôt d'allouer plus de mémoire à PHP qu'il faudrait ?
    (je ne sais plus exactement où est la modif à faire, peut-être le php.ini)

    Mais si tu penses que le problème est dans le dépassement de mémoire, je te conseillerais dans un premier temps d'essayer de tronquer tes fixtures et de laisser peu de données dedans : si le problème persiste, c'est que ce n'est pas un problème de dépassement de mémoire.

  3. #3
    Membre éclairé
    Inscrit en
    Juin 2006
    Messages
    534
    Détails du profil
    Informations forums :
    Inscription : Juin 2006
    Messages : 534
    Par défaut
    en faites le dépassement de mémoire est lié à la mise en cache de toute les requêtes exécutés par doctrine. Sur un PC un peu poussif, ça le met vite a genoux.
    J'ai trouvé cette parade sur le net:
    qui fonctionne (je la remet à true quand je veut tracé mes requêtes).

    par contre, le fait qu'il oublie certains data par enregistrement la je suis coincé.

    Comme mon appli à beaucoup de relations croisé, il est difficile de réduire le nombre d'enregistrement (si j'enlève un user, il peut être nécessaire comme responsable d'un site ou d'un pays, ou bien gérer une section ou ...).

  4. #4
    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 fixature n'est pas conçu, à l'origine pour faire de l'importation de données en masse. Il permet de peupler et repeupler la base de donnée, à l'identique, pour simplifier les tests développeurs et les tests automatique.

    Le mieux serait de passer par de bête (mais efficaces) fonction export importe.

    Et plutôt que de générer su yaml, génère du sql.

  5. #5
    Membre éclairé
    Inscrit en
    Juin 2006
    Messages
    534
    Détails du profil
    Informations forums :
    Inscription : Juin 2006
    Messages : 534
    Par défaut
    je croit que je n'aurait pas trop le choix malheureusement :/

  6. #6
    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
    Alors il faudra couper en petits paquets

Discussions similaires

  1. [VB6][MYSQL] recuperer des données MySQL via PHP
    Par psykotox dans le forum VB 6 et antérieur
    Réponses: 10
    Dernier message: 18/01/2008, 12h25
  2. chargement des données d'un datawarehouse syntaxe oracle
    Par Invité dans le forum Administration
    Réponses: 3
    Dernier message: 01/05/2007, 12h23
  3. Chargement des données d'une classe vers une autre
    Par nosdev dans le forum Access
    Réponses: 1
    Dernier message: 16/01/2007, 15h44
  4. Réponses: 2
    Dernier message: 20/11/2006, 15h35
  5. Chargement des drivers access via ODBC sous Qt 3
    Par Higestromm dans le forum Bases de données
    Réponses: 10
    Dernier message: 09/01/2006, 15h30

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