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

MkFramework Discussion :

Requête paramétrée avec deux parametres l'id du getSelect


Sujet :

MkFramework

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Août 2014
    Messages
    62
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Burkina Faso

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux
    Secteur : Service public

    Informations forums :
    Inscription : Août 2014
    Messages : 62
    Points : 28
    Points
    28
    Par défaut Requête paramétrée avec deux parametres l'id du getSelect
    Bonjour IMIKADO encore merci pour vos effort j'essaie de faire le bilan de mes activité sur une période donnée je veux permettre aux utilisateurs de choisir la période a travers le menu déroulant du getSelect. mais j'ai problème pour récupérer l'id des mois choisit pour les passer en paramètre dans ma requête! pour être plus explicite je vous envoie mes différente codes
    du coté de la vue
    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
     
    <?php 
    $oForm=new plugin_form($this->oMensuelafd);
    ?>
     
    <form class="form-horizontal" action="" method="POST" >
     
    <div class="form-group">
    		<label class="col-sm-3 control-label">Mois de debut :</label>
    		<div class="col-sm-3"> <?php echo $oForm->getSelect('idmois',$this->tJoinmodel_mois,array('class'=>'form-control'));  $month1=_root::getParam('idmois');?>  </div>
    	</div>
     
     
    	<div class="form-group">
    		<label class="col-sm-3 control-label">Mois de fin :</label>
     
    		<div class="col-sm-3"> <?php echo $oForm->getSelect('idmois',$this->tJoinmodel_mois,array('class'=>'form-control')); $month2=_root::getParam('idmois');
    		?></div>
    	</div>
     
     <a class="btn btn-default" href="<?php echo $this->getLink('mensuelafd::evolutionbilan')?>">BILAN DE L'EVOLUTION</a>
     
    <a class="btn btn-default" href="<?php echo $this->getLink('mensuelafd::list')?>">Retour</a>
     
    </form>
    du coté du model main

    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
    public function _recherche() {
     
    			$oMensuelafd=model_mensuelafd::getInstance()->findById( _root::getParam('idmois') );
    			$oView=new _view('mensuelafd::recherche');
    			$oView->oMensuelafd=$oMensuelafd;
     
    				$oView->tJoinmodel_mois=model_mois::getInstance()->getSelect();		
     
    		$this->oLayout->add('main',$oView);
     
    		}		
     
     
     
    		public function _evolutionbilan(){
     
    			$tMensuelafd=model_mensuelafd::getInstance()->evolutionbilan( _root::getParam('$month1','$month2') );
    			$oView=new _view('mensuelafd::evolutionbilan');
    			$oView->tMensuelafd=$tMensuelafd;
    			plugin_debug::addSpy('tableau de resultats',$tMensuelafd);
    			$oView->tJoinmodel_mois=model_mois::getInstance()->getSelect();
     
    			$this->oLayout->add('main',$oView);
    		}
    la requête du coté du model

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    public function evolutionbilan($month1,$month2){
    				return $this->findMany('SELECT sum(mensuelafd.precedentsuivie) as precedentsuivie,sum(mensuelafd.enqueteseffectue) as enqueteseffectue,sum(mensuelafd.famillecz) as famillecz,sum(mensuelafd.refuseafd) as refuseafd,((sum(mensuelafd.refuseafd)) / (sum(mensuelafd.famillecz))) as tauxderefus,sum(mensuelafd.entredumois) as entredumois,((sum(mensuelafd.precedentsuivie)) + (sum(mensuelafd.entredumois))) as nombretotalfamillessuivieperiode,sum(mensuelafd.totalsortie) as totalsortie,((sum(mensuelafd.precedentsuivie)) + (sum(mensuelafd.entredumois)) - (sum(mensuelafd.totalsortie))) as totalsuiviefin FROM  mensuelafd NATURAL JOIN mois WHERE mensuelafd.idmois between mois1 and mois2',array('mois1'=>$month1,'mois2'=>$month2));
     
    	}
    merci de bien vouloir éclairer ma lanterne sur ce sujet

  2. #2
    Rédacteur
    Avatar de imikado
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Décembre 2006
    Messages
    5 239
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Finance

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 239
    Points : 19 100
    Points
    19 100
    Billets dans le blog
    17
    Par défaut
    Il manque le traitement de votre formulaire:

    Dans votre module

    Code php : 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
     
    public function _recherche() {
     
    if(_root::getRequest()->isPost()){
     return $this->_evolutionbilan();
     
    }
     
    			$oMensuelafd=model_mensuelafd::getInstance()->findById( _root::getParam('idmois') );
    			$oView=new _view('mensuelafd::recherche');
    			$oView->oMensuelafd=$oMensuelafd;
     
    				$oView->tJoinmodel_mois=model_mois::getInstance()->getSelect();		
     
    		$this->oLayout->add('main',$oView);
     
    		}		
     
     
     
    		public function _evolutionbilan(){
     
    			$tMensuelafd=model_mensuelafd::getInstance()->evolutionbilan( _root::getParam('idmois') );
    			$oView=new _view('mensuelafd::evolutionbilan');
    			$oView->tMensuelafd=$tMensuelafd;
    			plugin_debug::addSpy('tableau de resultats',$tMensuelafd);
    			$oView->tJoinmodel_mois=model_mois::getInstance()->getSelect();
     
    			$this->oLayout->add('main',$oView);
    		}

    Vous noterez qu'il y a une erreur dans votre recuperation des mois
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    $tMensuelafd=model_mensuelafd::getInstance()->evolutionbilan( _root::getParam('$month1','$month2') );
    Il y a une erreur: _root::getParam('$month1','$month2') ne fonctionnera jamais:

    _root::getParam() sert à récupérer une variable GET/Post avec un nom défini, '$month1' ne sera jamais récupérable: soit vous utilisez une variable: $month1, soit une chaine de caractère: "idmois" ou autre, mais pas '$month1'

    Ensuite le deuxième paramètre de _root::getParam indique la valeur par défaut: si la variable GET/Post est inexistante
    Framework php sécurisé et simple à prendre en main avec générateur web http://mkframework.com/ (hebergé sur developpez.com)
    Mes cours/tutoriaux

  3. #3
    Nouveau membre du Club
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Août 2014
    Messages
    62
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Burkina Faso

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux
    Secteur : Service public

    Informations forums :
    Inscription : Août 2014
    Messages : 62
    Points : 28
    Points
    28
    Par défaut
    Bonjour,Fanchement je ne vois pas trop comment faire pour récupérer les idmois de mes deux getSelect, je vous fais voir la vue de la selection de mes mois pour le calcule des bilans
    Nom : Capture d'écran 2015-06-04 à 17.39.27.png
Affichages : 110
Taille : 17,6 Ko voici le code
    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
    <?php 
    $oForm=new plugin_form($this->oMensuelafd);
    ?>
    
    <form class="form-horizontal" action="" method="POST" >
    
    <div class="form-group">
    		<label class="col-sm-3 control-label">Mois de debut :</label>
    		<div class="col-sm-3"> <?php echo $oForm->getSelect('idmois',$this->tJoinmodel_mois,array('class'=>'form-control')); $month1=$this->oMensuelafd->idmois;?>  </div>
    	</div>
     
    
    	<div class="form-group">
    		<label class="col-sm-3 control-label">Mois de fin :</label>
    		
    		<div class="col-sm-3"> <?php echo $oForm->getSelect('idmois',$this->tJoinmodel_mois,array('class'=>'form-control')); $month2=$this->oMensuelafd->idmois;?>
    		</div>
    	</div>
    
     <a class="btn btn-default" href="<?php echo $this->getLink('mensuelafd::evolution')?>">BILAN DE L'EVOLUTION</a>
    <a class="btn btn-default" href="<?php echo $this->getLink('mensuelafd::list')?>">Retour</a>
    
    </form>

    et au niveau du main

    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
    public function _recherche() {
    			 
    			if(_root::getRequest()->isPost()){
    			 return $this->_evolutionbilan();
    			} 
    			$oMensuelafd=model_mensuelafd::getInstance()->findById( _root::getParam('idmois') );
    			$oView=new _view('mensuelafd::recherche');
    			$oView->oMensuelafd=$oMensuelafd;
     
    				$oView->tJoinmodel_mois=model_mois::getInstance()->getSelect();		
     
    		$this->oLayout->add('main',$oView);
     
    		}		
    		public function _evolution(){
    			
    			$tMensuelafd=model_mensuelafd::getInstance()->evolutionbilanmensuel(_root::getParam('month1'),_root::getParam('month2'));
    			$oView=new _view('mensuelafd::evolution');
    			$oView->tMensuelafd=$tMensuelafd;
    			plugin_debug::addSpy('tableau de resultats',$tMensuelafd);
    			$oView->tJoinmodel_mois=model_mois::getInstance()->getSelect();
    			$this->oLayout->add('main',$oView);
    			
    			}

  4. #4
    Rédacteur
    Avatar de imikado
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Décembre 2006
    Messages
    5 239
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Finance

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 239
    Points : 19 100
    Points
    19 100
    Billets dans le blog
    17
    Par défaut
    Les champs que vous recevez ne sont pas "month1" et "month2"
    mais "idmois"
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <?php echo $oForm->getSelect('idmois',
    Framework php sécurisé et simple à prendre en main avec générateur web http://mkframework.com/ (hebergé sur developpez.com)
    Mes cours/tutoriaux

  5. #5
    Rédacteur
    Avatar de imikado
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Décembre 2006
    Messages
    5 239
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Finance

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 239
    Points : 19 100
    Points
    19 100
    Billets dans le blog
    17
    Par défaut
    En effet la première ligne "rempli" votre formulaire avec votre objet oMensualafd
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $oForm=new plugin_form($this->oMensuelafd);
    Voila la vue "corrigée" que vous devriez avoir:

    <?php
    $oForm=new plugin_form($this->oMensuelafd);
    ?>

    <form class="form-horizontal" action="" method="POST" >

    <div class="form-group">
    <label class="col-sm-3 control-label">Mois de debut :</label>
    <div class="col-sm-3"> <?php echo $oForm->getSelect('month1',$this->tJoinmodel_mois,array('class'=>'form-control')); ?> </div>
    </div>


    <div class="form-group">
    <label class="col-sm-3 control-label">Mois de fin :</label>

    <div class="col-sm-3"> <?php echo $oForm->getSelect('month2',$this->tJoinmodel_mois,array('class'=>'form-control')); ?>
    </div>
    </div>

    <a class="btn btn-default" href="<?php echo $this->getLink('mensuelafd::evolution')?>">BILAN DE L'EVOLUTION</a>
    <a class="btn btn-default" href="<?php echo $this->getLink('mensuelafd::list')?>">Retour</a>

    </form>
    Framework php sécurisé et simple à prendre en main avec générateur web http://mkframework.com/ (hebergé sur developpez.com)
    Mes cours/tutoriaux

Discussions similaires

  1. [AC-2003] Requête paramétrée avec deux listes déroulantes.
    Par hadrimo dans le forum Access
    Réponses: 3
    Dernier message: 17/10/2014, 22h58
  2. Requête paramétrée avec deux paramètres
    Par Le gris dans le forum Requêtes
    Réponses: 4
    Dernier message: 23/08/2012, 12h35
  3. Réponses: 1
    Dernier message: 07/04/2010, 09h56
  4. [WD8] Requêtes paramétrées avec accès odbc direct
    Par devalender dans le forum WinDev
    Réponses: 5
    Dernier message: 20/12/2005, 13h25
  5. Déterminer une requête paramétrée avec LIKE
    Par priest69 dans le forum Access
    Réponses: 4
    Dernier message: 24/10/2005, 20h29

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