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

MVC PHP Discussion :

probleme de lecture dans BDD


Sujet :

MVC PHP

  1. #1
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2011
    Messages
    80
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Décembre 2011
    Messages : 80
    Points : 58
    Points
    58
    Par défaut probleme de lecture dans BDD
    Bonjour,
    J'ai crée une table qui contient plusieurs fois la meme information, et dans mon controlleur j'ai fait un fetchAll() pour récupérer ces informations mais comment est-ce que je dois procéder pour ne pas avoir de doublon ? et je ne sais pas quoi mettre dans mon model.
    Voici mon controlleur :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    public function rubriqueAction()
        {
    		$rubrique = new Application_Model_DbTable_Rubrique();
    		$this->view->rubrique = $rubrique->fetchAll();
        }

  2. #2
    Membre éprouvé
    Avatar de 5h4rk
    Homme Profil pro
    CTO at TabMo
    Inscrit en
    Février 2011
    Messages
    813
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : CTO at TabMo
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Février 2011
    Messages : 813
    Points : 1 297
    Points
    1 297
    Par défaut
    Bonjour,
    Quand tu parles de doublon tu dois vouloir parler d'une colonne en particulier, j'espère pour toi que ce ne sont pas les rows complètes qui sont en doublon.

    Il te faut donc dans ton modèle Application_Model_DbTable_Rubrique créé une méthode te retournant ce que tu veux, dans celle ci il faudra que tu ajoute la contrainte distinct sur la colonne voulu et tu passe la construction de ta requête en argument à ton fetchALL puis tu retournes le résultat.

    Cela va être du genre suivant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    $where = $this->select();
    $where->...; (ton distinct devra être à ce niveau)
    return $this->fetchAll($where);

  3. #3
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2011
    Messages
    80
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Décembre 2011
    Messages : 80
    Points : 58
    Points
    58
    Par défaut
    merci de ton aide mais en fait j'ai tout mis dans mon controlleur car je sais pas comment l'appeler si je crée une méthode dans mon model , je te montre mon code si tu peux me dire quoi laisser dans mon controlleur et quoi mettre exactement dans le model ça serait cool

    COntrolleur :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    class UserController extends Zend_Controller_Action
    { 
        public function rubriqueAction()
        {
    		$db =Zend_Registry::get('dba');
    		$req = $db->select()
    				->distinct()
    				->from('zone', 'page');
    		$result = $db->fetchAll($req);
    		Zend_Debug::dump($result);
     
        }
    }

  4. #4
    Membre éprouvé
    Avatar de 5h4rk
    Homme Profil pro
    CTO at TabMo
    Inscrit en
    Février 2011
    Messages
    813
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : CTO at TabMo
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Février 2011
    Messages : 813
    Points : 1 297
    Points
    1 297
    Par défaut
    Si tu créés une méthode du genre dans ton modèle:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    public function selectAllRow() {
    ...
    }
    Dans ton controller tu l'appel ainsi :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    Tu commence par initialiser ton modèle
    $tonmodel->selectAllRow();

  5. #5
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2011
    Messages
    80
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Décembre 2011
    Messages : 80
    Points : 58
    Points
    58
    Par défaut
    voilà comment j'ai fait

    Controlleur :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    public function rubriqueAction()
        {
    		$rubrique = new Application_Model_DbTable_Rubrique();
    		$this->view->rubrique = $rubrique->obtenirRubrique();
     
        }
    Model :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    public function obtenirRubrique()
    	{
    		$db =Zend_Registry::get('dba');
    		$req = $db->select()
    				->distinct()
    				->from('zone', 'page');
    		$result = $db->fetchAll($req);
    		Zend_Debug::dump($result);
     
    	}
    mais j'ai une erreur qui me dit l'adpater n'a pas été trouver pour le model demander

  6. #6
    Membre éprouvé
    Avatar de 5h4rk
    Homme Profil pro
    CTO at TabMo
    Inscrit en
    Février 2011
    Messages
    813
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : CTO at TabMo
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Février 2011
    Messages : 813
    Points : 1 297
    Points
    1 297
    Par défaut
    Vu que tu es dans un modele, tu n as pas besoin de récupérer dba dans le registre utilise $this comme je l ai indiqué dans mon post

  7. #7
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2011
    Messages
    80
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Décembre 2011
    Messages : 80
    Points : 58
    Points
    58
    Par défaut
    alors j'ai fait comme tu m'as dit mais j'ai une erreur de "unexpected T_VARIABLE" tu pourras peut etre m'indiquer la faute

    Controlleur:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     public function rubriqueAction()
        {		
    		$rubrique = new Application_Model_DbTable_Rubrique();
    		$this->view->rubrique = $rubrique->obtenirRubrique();
     
        }
    Model:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    public function obtenirRubrique()
    	{
    		$where = $this->select();
    		$where->from('zone', 'page');
     
    		$return $this->fetchAll($where);		
    	}

  8. #8
    Membre éprouvé
    Avatar de 5h4rk
    Homme Profil pro
    CTO at TabMo
    Inscrit en
    Février 2011
    Messages
    813
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : CTO at TabMo
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Février 2011
    Messages : 813
    Points : 1 297
    Points
    1 297
    Par défaut
    Ton erreur c est return et non $return.

    Il serait bon de te relire des erreurs comme celle ci tu devrais pouvoir les régler seul

  9. #9
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2011
    Messages
    80
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Décembre 2011
    Messages : 80
    Points : 58
    Points
    58
    Par défaut
    j'avais mis un $ devant return , tout marche bien et merci encore pour ton aide 5h4rk

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [MySQL] Probleme d'ajout dans BDD mysql
    Par Invité dans le forum PHP & Base de données
    Réponses: 8
    Dernier message: 07/06/2012, 15h29
  2. probleme de lecture dans des fichiers
    Par xanatos dans le forum VB.NET
    Réponses: 1
    Dernier message: 21/03/2008, 15h19
  3. [C# CF1.1]Probleme de lecture dans un fichier texte
    Par Papy_Guik dans le forum Windows Mobile
    Réponses: 10
    Dernier message: 21/05/2007, 17h43
  4. Probleme de lecture dans un fichier
    Par Bebert71 dans le forum C
    Réponses: 7
    Dernier message: 15/01/2007, 19h28
  5. Probleme de filtre dans bdd
    Par scorpiwolf dans le forum C++Builder
    Réponses: 2
    Dernier message: 04/06/2002, 10h43

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